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内 容 简 介 


《PHP 开发 实战 1200 例 》 包 括 第 工 卷 、 第 开卷 共计 1200 个 例子 ， 本 书 是 第 工 卷 ， 共 计 625 个 例子 。 

本 书 以 开发 人 员 在 项 目 开 发 中 经 常 遇 到 的 问题 和 必须 掌握 的 技术 为 中 心 ， 介绍 了 应 用 PHP 进行 Web 开发 的 各 个 方 
面 的 知识 和 技巧 ， 主 要 包括 开发 环境 、PHP 基础 、Web 页 面 交互 、 文 件 操作 、 会 话 应 用 、 图 形 图 像 处理 及 面向 对 象 等 
内 容 。 全 书 分 为 5 篇 15 章 ， 共 计 625 个 实例 和 625 个 经 验 技巧 。 每 个 实例 都 经 作者 精心 筛选 ， 具 有 很 强 的 实用 性 ， 其 
中 一 些 实例 是 开发 人 员 难 于 寻 疯 的 解决 方案 。 

本 书 两 卷 共计 1200 个 例子 ， 包 括 了 开发 中 各 个 方面 最 常用 的 实例 ， 是 目前 市 场 上 实例 最 全 面 的 开发 类 图 书 ， 书 中 
实例 来 源 于 多 位 工程 师 的 多 年 积累 ， 具 有 很 强 的 实用 性 。 

本 书 附带 有 配套 DVD 光盘 ， 光 盘 中 提供 有 部 分 实例 的 视频 和 大 部 分 源 代 码 ， 读 者 稍 加 修改 即 可 应 用 。 

本 书 适 合 PHP 的 初学 者 ， 如 高 校 学 生 、 求 职 人 员 作 为 练习 、 速 查 、 学 习 使 用 ， 也 适合 PHP 程序 员 参 考 、 查 阅 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 。 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举 报 电话 : 010-62782989 13701121933 
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特别 说 明 : 

《PHP 开发 实战 1200 例 》 包 括 第 工 卷 、 第 正 卷 共计 1200 个 例子 ， 本 书 是 第 工 卷 ， 包 含 625 个 例子 。 

程序 开发 是 一 项 艰辛 的 工作 ， 它 不 仅 考验 开发 人 员 的 智力 ， 更 考验 开发 人 员 的 体力 。 纵 观 国内 的 软件 企业 ， 
内 部 开发 团队 挑灯 夜战 、 连 续 加 班 是 常 有 的 事情 。 笔 者 曾 有 幸 参 加 过 十 几 个 项 目的 开发 工作 ， 对 编程 有 深刻 的 体 
会 。 编 程 是 一 项 复杂 的 创造 性 工作 ,不仅 需要 开发 人 员 掌 握 各 方面 的 知识 ， 还 需要 开发 人 员 具 有 丰富 的 开发 经 验 。 
项 目 开发 中 的 一 个 问题 可 能 会 占用 团队 几 天 甚至 十 几 天 的 时 间 ， 但 是 如 果 开 发 人 员 遇 到 过 类 似 的 问题 ， 也 许 几 分 
钟 就 可 以 解决 。 这 就 是 编程 经 验 的 重要 性 ， 也 是 许多 软件 企业 招聘 时 选择 有 项 目 开发 经 验 人 员 的 主要 原因 。 

本 书 精 选项 目 开 发 中 的 625 个 实例 ， 涵 盖 PHP 基础 、Web 页 面 交互 、 文 件 操作 、 面 向 对 象 、MySQL 数据 
库 、ADODB 类 库 和 Smarty 模板 等 方面 的 内 容 ， 每 一 个 知识 点 都 提供 有 丰富 的 、 具 有 很 强 实用 性 的 实例 ， 帮 助 
开发 人 员 快速 解 决 疑难 问题 。 


本 书 内 容 


本 书 分 为 5 篇 15 章 内容 ， 共 计 625 个 实例 。 书 中 亡 选 实例 均 来 源 于 一 线 开 发 人 员 的 实际 开发 项 目 ， 涵 盖 开 


内 容 导航 如 下 图 所 示 。 
亮点 内 容 导 航 
第 2 篇 常用 技术 篇 (124 个 实例 ) 


第 1 篇 基础 篇 (222 个 实例 ) 


第 3 篇 数据 库 篇 (191 个 实例 ) 
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第 5 篇 ”综合 应 用 篇 (44 个 实例 ) 
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为 了 方便 读者 学 习 书 中 的 实例 ， 积 累 开发 经 验 ， 本 书 在 讲解 实例 时 按照 实例 说 明 、 关 键 技术 、 设 计 过 程 和 


秘笈 心 法 4 个 阶段 进行 。 
实例 说 明 


实例 说 明 部 分 利用 图 文 结合 的 方式 , 介绍 实例 的 特点 、 功 能 和 运行 效果 ,使 读者 快速 了 解 实例 的 作用 、 


可 以 从 实例 中 学 到 的 技能 。 
关键 技术 


关键 技术 部 分 剖析 实例 使 用 的 核心 技术 。 这 样 ， 读 者 不 必 查 看 设计 过 程 和 源 代码 就 可 以 快速 掌握 实例 


的 关键 技术 ， 甚 至 直接 做 出 实例 。 
回 ”设计 过 程 


设计 过 程 部 分 详细 介绍 实例 的 开发 过 程 。 读 者 可 以 按照 该 部 分 内 容 做 出 自己 的 实例 程序 。 


回 ”秘笈 心 法 


秘笈 心 法 部 分 给 出 与 实例 相关 的 技巧 、 注 意 事项 或 经 验 总 结 ， 丰 富 读者 的 编程 经 验 。 


下 图 展示 了 一 个 完整 实例 的 文档 缩 略图 。 


光 僵 位 置 ， 光盘 MR 06275 


通过 图 像 显 示 密 码 安 全 强度 . 
焰 格 数 ， 依依 让 向, 


"加 ”实例 说 明 。 


在 本 实例 中 , 将 介绍 图 像 的 另 一 项 妙用 一 一 显示 注册 
填写 密码 的 安全 强度 。 运 行 本 实例 ， 当 在 密码 文本 框 中 输 
入 一 个 密码 时 ， 光 标 离开 后 ,将 自动 判断 这 个 密码 的 安全 
强度 ， 并 以 图 像 的 形式 返回 判断 结果 ， 其 运行 结果 如 图 6.6 


所 示 。 
OO, nt 
o 一 一 


NPE 


图 66 
"加 ”关键 技术 。 


对 密码 的 安全 强度 进行 判断 是 在 JavaScript 脚本 
中 ， 应 用 正则 表达 式 来 完成 的 ， 其 原理 如 下 : * 

(1) 对 密码 中 的 值 进 行 判断 ， 如 果 只 包含 数字 、 
英文 字符 串 或 者 特殊 字符 串 中 的 任意 一 种 ， 那 么 说 明 
密码 安全 强度 差 。+ 

(2) 对 密码 中 的 值 进行 判断 ， 如 果 包 含 数 字 、 英 
文字 符 串 或 者 特殊 宇 符 串 中 的 任意 两 种 ， 那 么 说 明 窗 
码 安全 强度 中 。+ 

〈3) 对 密码 中 的 值 进行 判断 , 如 果 同时 包含 数字 、 


通过 图 像 显示 密码 安全 强度 " 


英文 字符 串 和 特殊 字符 串 ， 那 么 说 明 密码 安全 强度 强 。* 


中 
级 
"图 ”设计 过 程 。 


本 实例 完成 一 个 用 户 注册 的 功能 ， 并 且 在 表单 中 
通过 JavaScript 脚本 对 提交 的 元 素 进行 判断 , 最 终 符合 
要 求 后 ， 将 用 户 注册 信息 添加 到 指定 的 数据 表 中 。*" 

(1) 创建 ndex .php 页 面 ， 完 成 用 户 注册 页 面 和 
表单 的 设计 , 通过 JavaScript 对 表单 中 提交 的 值 进行 判 
断 , 并 直接 将 判断 的 结果 反馈 到 div 标签 中 ， 最 终 将 表 
单 中 的 数据 提交 到 index_ok.php 文件 中 ， 完 成 用 户 注 


册 的 操作 。* 
‘<form name="fomn reg” mathod="post” action="index_ ok php" 
enSubmit="reum cbjvseipfolfom._rag, dl)"> ， 
a, 
‘<td baight="30><div align="right"> 阁 三 : </div></td> ， 


id er"30" 


/fonp &rbsp; ， 
<div ide"chlnew_ pwd" style="color. sFFOO00"><ldiv> | 


<d> 
cp 
Tfom>, 
(2) 编写 JavaScript 脚本 ， 创 建 checkjs 脚本 文 
件 ， 完 成 对 表单 中 提交 的 值 进 行 判 断 。* 
(3) 创建 mdex_ok .php 文件 ， 获 取 表 单 中 提交 的 
数据 ， 将 数据 添加 到 指定 的 数据 表 中 。* 
(4) 创建 conn php 文件 ， 完 成 MySQL 服务 器 和 
MySQL 数据 库 的 连接 操作 ， 并 设置 编码 格式 为 utf-& 
* 硬 ”秘笈 心 法 
心 法 领悟 275: 正则 表达 式 的 运用 。* 
在 本 实例 中 ,不 只 一 次 使 用 了 正则 表达 式 。 分 别 通过 
正则 表达 式 对 密码 的 强度 、 手 机 号 码 、 座 机 号 码 以 及 邮箱 
地 址 进行 判断 。 
“130a{9)s "150a{9D5 1890d(8)S 判断 插 机 号 
于 


0a} Xf Gal4} X07Dsr (af4) 0Gf8))S 1 讲 江 主机 号 
/J / 光 和 


本 书 特点 


实例 极为 丰富 

本 书 第 工 卷 、 第 开卷 共 精 选 了 1200 个 实例 和 1200 个 经 验 技巧 ， 涵 盖 了 编程 中 多 个 方面 的 各 种 应 用 。 用 户 
开发 中 所 需 的 技术 、 技 巧 在 本 书 几 乎 都 可 以 找到 。 

例子 非常 实用 

书 中 所 选 实例 均 是 项 目 开 发 中 经 常 需 要 使 用 或 实现 的 技术 ， 由 数 名 工程 师 多 年 积累 而 成 ， 许 多 实例 是 开发 
人 员 梦 襟 以 求 的 。 

回 “ 可 操作 性 很 强 

本 书 实例 都 给 出 了 程序 说 明 、 设 计 思 路 、 设 计 步 骤 、 源 程序 等 内 容 ， 读 者 可 按部就班 地 直接 使 用 。 

加 ”完善 的 技术 服务 

为 了 帮助 读者 尽快 理解 内 容 ， 读 者 朋友 可 通过 QQ、BBS、 邮 箱 、 电 话 等 多 种 形式 获取 相关 问题 的 答复 。 


本 书 DVD 光盘 


为 了 帮助 读者 学 习 和 使 用 书 中 的 实例 , 本 书 附 赠 有 DVD 光盘 ,其 中 不 仅 提 供 了 书 中 所 有 实例 项 目的 源 代码 、 
素材 ， 还 提供 了 关键 实例 的 开发 视频 讲解 及 PHP 学 习 资 料 。 光 盘 目 录 如 下 图 所 示 。 


上传 多 个 文件 到 服务 器 .exe] 


Br 

国 .htaccess 
|p] INDEX_OK PHP 
月 TIDEX FHP 


回赠 PE 学 习 资料 


已 ab_database04 


加 PIP 范例 大 全 ( 第 工 卷 ) 光盘 使 用 说 明 


本 书 约定 


回 “实例 使 用 方法 

用 户 在 学 习 本 书 的 过 程 中 ， 可 以 从 光盘 中 复制 实例 ， 去 掉 实 例 的 只 读 属性 。 有 些 实例 需要 使 用 相应 的 数据 
库 或 第 三 方 资源 ， 这 些 实例 在 使 用 前 需要 进行 相应 配置 ， 详 细 使 用 方式 请 参考 本 书 的 光盘 使 用 说 明 书 。 此 外 ， 
如 果 用 户 直 接 将 本 书 实例 用 于 商业 用 途 ， 由 此 产生 的 不 良 后 果 由 用 户 自 己 承担 。 

实例 及 录像 位 置 

书 中 实例 在 光盘 中 的 存储 格式 为 “MR\ 章 号 \ 实 例 序 号 ”。 例 如 ，“MR\04\096” 表 示 实 例 096， 位 于 第 4 章 。 书 
中 关键 实例 在 光盘 中 提供 了 开发 录像 ， 录 像 的 存储 格式 与 实例 的 存储 格式 是 相同 的 。 例 如 ， 查 看 实例 096 的 开 
发 录像 ， 可 以 在 光盘 中 的 “MR\04\096” 路 径 下 找到 ， 录 像 名 称 与 实例 名 称 相同 ， 格 式 为 EXE 格式 。 

录像 使 用 说 明 

本 书 赠送 的 实例 录像 采用 EXE 文件 格式 ， 无 须 使 用 播放 器 ， 双 击 就 可 以 直接 播放 。 在 主 目录 中 ， 目 录 前 有 
录像 图 标的 实例 ， 表 示 在 光盘 中 存在 视频 录像 。 
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部 分 实例 只 给 出 关键 代码 
由 于 篇 幅 限制 ， 书 中 有 些 实 例 只 给 出 了 关键 代码 ， 完 整 代码 请 参考 光盘 实例 程序 。 


读者 人 群 


本 书 非常 适合 以 下 人 员 阅 读 : 
回 ”PHP 初学 者 ， 如 高 校 大 学 生 、 求 职 人 员 、 培 训 机 构 学 员 
回 PHP 程序 员 


学 习 答疑 


如 果 您 在 学 习 或 使 用 本 书 的 过 程 中 遇 到 问题 或 疑惑 ， 可 以 通过 如 下 方式 与 我 们 联系 。 
服务 网 站 : www.mingribook.com 

服务 QQ: 100310265 或 100310063 

服务 信箱 : mingrisoft@mingrisoft.com 

服务 电话 : 0431-84978981/84978982 

学 习 社 区 : www.mrbccd.com 


我 们 承诺 将 在 5 个 工作 日 内 给 您 提供 解答 。 


本 书 作者 


图 图 图 加 加 


本 书 由 明日 科技 组 织 编写 ， 参 加 编写 的 程序 员 有 潘 凯 华 、 刘 中 华 、 杨 明 、 刘 欣 、 李 慧 、 董 大 永 、 李 继 业 、 
尹 强 、 张 舌 、 赛 硅 春 、 高 春 攀 、 宋 坤 、 刘 锐 宁 、 梁 水 、 李 伟 明 、 刘 彬 彬 、 安 剑 、 孙 秀 梅 、 巩 建华 、 房 大 伟 、 吕 
双 、 刘 云 峰 、 王 国 辉 、 李 钟 尉 、 张 振 坤 、 陈 丹 丹 、 赵 会 东 、 卢 翰 、 白 伟 明 、 王 小 科 、 梁 晓 岚 、 杨 丽 、 顾 丽 丽 、 
刘 龄 龄 、 张 座 国 、 王 乐 乐 、 陈 英 、 刘 莹 、 李 贺 、 李 鑫 等。 由 于 作者 水 平 有 限 ， 疏 漏 和 不 足 之 处 在 所 难免 ， 请 广 
大 读者 朋友 批评 指正 。 
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第 14 章 Smarty 模板.… 
14.1 环境 搭建 
全 5 实例 557 smarty 开发 环境 搭建 
实例 558 ”Smarty 模板 的 配置 … 

俩 实例 559 封装 smarty 模板 的 配置 方法 
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14.3 ”综合 应 用 
实例 567 Smarty 模板 制作 用 户 注 册页 面 oy 
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实例 608 ”购物 车 功能 实现 
15.7 图 书 订单 处 理 .… 
实例 609 填写 收 货 人 信息 
实例 610 ”确认 订购 信息 . 
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15.11 图 书 管理 
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15.12 用 户 管理 
实例 622 用 户 管理 
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第 1 章 PHP 与 Ming 扩展 库 

1.1 Ming 扩展 库 基 本 应 用 
实例 001 加 载 Ming 扩展 库 
实例 002 ”创建 一 个 漂亮 的 按钮 
实例 003 静态 输出 “吉林 省 明日 科技 ” 
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1.2 Ming 扩展 库 绘制 线段 
实例 006 绘制 一 条 直线 
实例 007 绘制 一 条 曲线 
实例 008 ”绘制 一 条 旋转 直线 

1.3 Ming 扩展 库 绘 制图 形 
实例 009 绘制 一 个 圆 
实例 010 ”绘制 一 个 正方 形 
实例 011 控制 图 片 向 上 移动 
实例 012 控制 图 片 向 下 移动 
实例 013 ”控制 图 片 的 旋转 


第 2 章 PHP 与 ImageMagick 图 片 处 理 
2.1 ImageMagick 处 理 图 片 
实例 014 下 载 、 安 装 ImageMagick 
实例 015 判断 指定 的 图 片 是 否 存在 
实例 016 读 取 图 片 信息 
实例 017 裁剪 指定 的 图 片 
实例 018 将 图 片 由 PNG 格式 转换 为 JPEG 格式 
实例 019 对 JPEG 格式 的 照片 进行 压缩 
2.2 ImageMagick 应 用 
实例 020 控制 图 片 45 度 旋转 
实例 021 绘制 图 片 的 缩 略 图 
实例 022 为 照片 加 上 泻 染 效 果 
实例 023 按照 原始 比例 缩放 图 片 
实例 024 制作 个 人 照片 的 画册 


第 3 章 AJAX 无 刷新 技术 
3.1 Ajax 操作 图 像 
实例 025 ”AJAX 无 刷新 图 像 上 传 
实例 026 ”AJAX 无 刷新 输出 上 传 图 像 


实例 027 AJAX 无 刷新 载 入 
实例 028 ”AJAX 动态 生成 缩 略 图 
实例 029 AJAX 动态 图 库 
3.2 ”Ajax 控制 表单 
实例 030 Ajax 检测 用 户 名 是 否 被 占用 
实例 031 Ajax 无 刷新 下 拉 列 表 
实例 032 ”Ajax 无 刷新 级 联 下 拉 列 表 
实例 033 ”AJAX 验证 用 户 注册 信息 
实例 034 AJAX 开发 带 记忆 功能 的 查询 
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实例 035 ”AJAX 无 刷新 创建 XML 文件 
实例 036 AJAX 无 刷新 读 取 XML 文件 
实例 037 AJAX 无 刷新 查询 XML 文件 
实例 038 AJAX 无 刷新 修改 XML 文件 
实例 039 AJAX 无 刷新 删除 XML 文件 
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实例 040 AJAX 导航 菜单 
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实例 042 AJAX 日 志 提醒 
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实例 044 ”AJAX 无 刷新 分 页 
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实例 048 ”AJAX 无 刷新 绘制 折线 图 
实例 049 AJAX 无 刷新 显示 聊天 信息 
实例 050 AJAX 无 刷新 发 布 在 线 电影 评论 信息 
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4.1 网 页 特效 

实例 051 jQuery 生成 网 页 特效 
实例 052 图 片 幻灯 片 
实例 053 ”颜色 拾取 器 
实例 054 广告 轮 显 
实例 055 图 片 放大 镜 
实例 056 jQuery 幕 帘 效果 
实例 057 jQuery 动态 变化 的 数字 


实例 058 
实例 059 
实例 060 
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jQuery 淡 入 淡出 动画 效果 
jQuery 上 下 卷 帘 动 画 效果 
jQuery 弹出 效果 
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实例 060 
实例 061 
实例 062 
实例 063 
实例 064 
实例 065 
实例 066 
实例 067 
实例 068 
实例 069 


检测 用 户 名 是 否 被 占用 
jQuery 验证 表单 元 素 
密码 强度 检测 
文本 框 提示 标签 

文本 编辑 器 

右键 菜单 
jQuery 二 级 联动 下 拉 列 表 
jQuery 三 级 联动 下 拉 列 表 
复 选 框 的 全 选 反选 不 先 
表单 动态 变色 
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实例 071 
实例 072 
实例 073 
实例 074 
实例 075 
实例 076 
实例 077 
实例 078 
实例 079 
实例 080 


jQuery 横向 导航 

jQuery 坚 向 导航 

jQuery 弹出 层 

jQuery 滑动 门 

jQuery 可 编辑 表格 
jQuery 实现 表格 隔行 变色 
jQuery 拖 搜 

jQuery 翻滚 的 消息 动态 
jQuery 动态 换 肤 

可 展开 和 关闭 的 表格 
单行 左右 移动 的 消息 提示 
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实例 081 
实例 082 


实例 083 


实例 084 


jQuery 与 GD2 函数 动态 输出 网 站 访问 量 
jQuery 与 Jpgraph 动态 制作 折线 图 分 析 网 站 
访问 量 

jQuery 与 Jpgraph 动态 制作 柱 形 图 统计 编程 
词典 年 销量 

jQuery 与 Jpgraph 动态 制作 3D 饼 形 图 分 析 
图 书市 场 的 占有 率 
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实例 085 
实例 086 
实例 087 
实例 088 
实例 089 


通过 jQuery 创建 XML 文件 
通过 jQuery 读 取 XML 文件 
通过 jQuery 查询 XML 文件 
通过 jQuery 修改 XML 文件 
通过 jQuery 删除 XML 文件 


第 5 章 PHP 与 在 线 编辑 工具 
5.1 自 定义 在 线 编辑 器 


实例 090 
实例 091 


自 定义 在 线 编辑 器 
在 博客 中 应 用 自 定义 在 线 编辑 器 


5.2 ”FCKeditor 在 线 编辑 器 


实例 092 
实例 093 
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CKEditor 网 页 编辑 器 
将 CKEditor 网 页 编辑 器 嵌入 到 后 台 


实例 094 
实例 095 


管理 系统 中 
Fckeditor 文本 编辑 器 
在 论坛 的 帖子 回复 中 应 用 FCKeditor 


第 6 章 PHP 与 多 媒体 技术 
6.1 操控 音频 文件 
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实例 097 
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实例 100 
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实例 103 
实例 104 
实例 105 
实例 106 
实例 107 
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在 线 音乐 上 传 

在 线 音乐 下 载 

MP3 在 线 点 播 

MP3 下 载 

创建 .m3u 格式 的 文件 

无 刷新 删除 .m3u 格式 的 文件 

通过 object 标签 向 HTML 页 中 载 入 多 媒体 
通过 embed 标签 向 HTML 页 中 载 入 多 媒体 
歌词 的 同步 输出 

在 线 播放 列表 

在 线 音乐 的 循环 播放 

在 线 音乐 的 连续 播放 

收藏 其 他 网 站 的 音乐 


6.2 操控 影音 文件 


实例 109 
实例 110 
实例 111 
实例 112 
实例 113 
实例 114 


通过 Real 播放 器 播放 视频 文件 

通过 Media Player 播放 器 播放 视频 文件 
控制 播放 器 窗口 的 状态 

播放 flv 视频 文件 

在 网 页 中 加 入 可 控 的 背景 音乐 

在 博客 中 加 入 可 控 的 背景 音乐 


6.3 操控 Flash 动画 文件 


实例 115 
实例 116 
实例 117 
实例 118 
实例 119 


在 网 页 中 嵌入 Flash 

在 网 页 中 嵌入 背景 透明 的 Flash 
向 Flash 中 传递 参数 

媒 入 Flash 播放 器 

播放 SFW 文件 
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7.1 编辑 、 设 计 PDF 文档 


实例 120 
实例 121 
实例 122 
实例 123 
实例 124 
实例 125 
实例 126 


配置 FPDF 

创建 FPDF 文档 

下 载 FPDF 文档 

向 FPDF 中 插入 图 片 
设置 FPDF 的 页 眉 和 页 脚 
通过 FPDF 绘制 表格 
设置 FPDF 的 编码 格式 
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实例 127 
实例 128 
实例 129 
实例 130 
实例 131 


设计 编程 词典 说 明 书 PDF 文档 

设计 编程 词典 产品 介绍 PDF 文档 

设计 编程 词典 安装 说 明 PDF 文档 

动态 生成 编程 词典 注册 用 户 的 PDF 文档 
设计 毕业 论文 的 PDF 文档 


第 8 章 报表 与 打印 技术 
8.1 操作 WORD 
实例 132 将 表格 数据 保存 到 Word 
实例 133 将 查询 结果 保存 到 Word 
实例 134 将 Web 页 中 的 表格 导出 到 Word 并 打印 
实例 136 ”打开 指定 的 Word 文档 并 打印 
实例 137 调用 Word 自动 打印 指定 格式 的 会 议 记录 
8.2 操作 EXCEL 
实例 138 将 MySQL 数据 表 中 数据 导出 到 Excel 
实例 139 将 查询 结果 导出 到 Excel 
实例 130 将 Web 页 面 中 的 数据 导出 到 Excel 
实例 140 将 Web 页 面 中 的 数据 导出 到 Excel 并 自动 
打印 
将 Excel 中 的 考勤 数据 导入 到 MySQL 数据 库 
将 Excel 中 的 工资 数据 导入 到 SQL Server 
数据 库 


实例 141 
实例 142 
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第 9 章 网 络 、 服 务 与 服务 器 

9.1 获取 服务 器 信息 
实例 157 根据 中 地 址 获取 主机 名 称 
实例 158 根据 主机 名 称 获取 他 地 址 
实例 159 ”获取 主机 的 所 有 他 地 址 
实例 160 将 思 地 址 转换 为 整数 
实例 161 将 整数 型 他 地 址 还 原 为 4 个 圆 点 分 隔 形 式 

9.2 ”Socket 实现 “C/S” 通 信 
实例 162 ”创建 Socket 服务 器 
实例 163 ”创建 Socket 客户 端 
实例 164 ”通过 Socket 发 送 短信 
实例 165 短信 群发 
实例 166 短信 自动 回复 

9.3 常见 网 络 任务 
实例 167 验证 服务 器 是 否 连接 
实例 168 开发 端口 扫描 器 
实例 169 ”设计 子 网 掩 码 转换 器 
实例 170 测试 用 户 带 宽 


第 10 章 ”邮件 处 理 技术 

10.1 配置 服务 器 
实例 171 SMTP 和 POP3 服务 器 的 安装 与 配置 
实例 172 ”Winmail 服务 器 的 安装 与 配置 
实例 173 通过 mail0 函 数 发 送 邮件 

10.2 通过 imap 电子 邮件 系统 函数 操作 邮件 
实例 174 登录 邮件 服务 器 
实例 175 ”接收 邮件 
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实例 143 ”对 Excel 中 的 考勤 数据 进行 统计 分 析 
8.3 报表 打印 
实例 144 利用 下 自身 的 打印 功能 实现 打印 
实例 145 ”打印 指定 框架 中 的 内 容 
实例 146 使 用 webBrowse 打印 报表 
实例 147 ”设置 页 眉 页 脚 
实例 148 利用 CSS 样式 打印 页 面 中 指定 内 容 
实例 149 利用 CSS 样式 实现 分 页 打印 
8.4 报表 打印 实战 应 用 
实例 150 打印 汇款 单 
实例 151 打印 快递 单 
实例 152 打印 信封 
实例 153 打印 库存 统计 报表 
实例 154 ”打印 用 户 的 通讯 记录 
实例 155 ”打印 公司 的 考勤 记录 
实例 156 打印 工资 条 
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实例 176 
实例 177 
实例 178 
实例 179 
实例 180 


浏览 邮件 

下 载 附件 

查找 邮件 

发 送 邮件 

发 送 带 附件 的 邮件 
实例 181 邮件 群发 
实例 182 ”删除 邮件 

10.3” Zend_mail 组 件 发 送 邮 件 
实例 183 ”Zend_mail 组 件 发 送 邮件 
实例 184 Zend_mail 组 件 发 送 HTML 格式 文本 邮件 
实例 185 ”Zend_mail 组 件 发 送 附件 
实例 186 ”Zend_mail 组 件 发 送 群 邮件 
实例 187 Zend_mail 组 件 接收 邮件 
实例 188 ”Zend_Mail 组 件 获取 邮件 内 容 


第 11 章 XML 操作 技术 
11.1 读 取 XML 文件 
实例 189 写 入 XML 文 件 
实例 190 读 取 XML 文 件 
实例 191 修改 XML 文 件 
实例 192 在 MySQL 中 读 取 XML 数据 
11.2 XML 文件 节点 操作 
实例 193 插入 XML 节点 
实例 194 检索 XML 节点 
实例 195 删除 XML 节点 
11.3 XML 文件 转换 
实例 196 在 HTML 页 面 中 使 用 XML 文件 
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实例 197 DataSet 和 XML 文件 的 相互 转换 
实例 198 XSL 转换 XML 文件 
11.4 XML 文件 加 密 、 解 密 
实例 199 加 密 XML 文件 
实例 200 解密 XML 文件 
11.5 动态 操作 XML 
实例 201 PHP 动态 创建 XML 文档 
实例 202 ”PHP 动态 添加 XML 数据 
实例 203 ”PHP 动态 查询 XML 数据 
实例 204 PHP 动态 修改 XML 数据 
实例 205 PHP 动态 删除 XML 数据 
11.6 XML 实战 应 用 一 一 留言 板 
实例 206 用 户 注册 
实例 207 用 户 登录 
实例 208 ”发布 留言 
实例 209 浏览 留言 
实例 210 编辑 留言 
实例 211 删除 留言 
11.7 XML 实战 应 用 一 一 RSS 阅读 器 
实例 212 创建 支持 RSS 阅读 的 站 点 
实例 213 动态 创建 RSS 文件 
实例 214 创建 RSS 阅读 器 的 框架 
实例 215 添加 频道 组 
实例 216 ”删除 频道 组 
实例 217 添加 频道 
实例 218 ”删除 频道 
实例 219 ” 树 状 导航 菜单 输出 频道 组 和 频道 
实例 220 AJAX 无 刷新 读 取 订 阅 信息 


第 12 章 Web 服务 器 与 远程 过 程 调用 
12.1 SOAP 扩展 

实例 221 Windows 下 安装 、 配 置 SOAP 

实例 222 建立 WSDL 文 件 

实例 223 ”建立 SOAP 客户 端 

实例 224 建立 SOAP 服务 器 端 

实例 225 PHP 操作 SOAP 

实例 226 PHP 与 WebService 交 互 

实例 227 PHP 通过 Web Service 发 送 短信 
12.2 XML-RPC (远程 过 程 调用 ) 

实例 228 客户 端 请 求 的 XML 格式 

实例 229 ”服务 器 响应 的 XML 格式 

实例 230 ”错误 信息 的 XML 格式 


实例 231 XML-RPC 的 综合 应 用 一 一 数学 运算 
第 13 章 LDAP ( 轻 量 级 目录 访问 协议 ) 


13.1 LDAP 服务 器 的 安装 与 配置 
实例 232 ”安装 LDAP 服务 器 
实例 233 ”配置 LDAP 服务 器 


XX 


实例 234 


OpenLDAP 的 启动 和 关闭 


13.2 ”通过 命令 操作 LDAP 服务 器 


实例 235 
实例 236 


通过 命令 向 OpenLDAP 服务 器 中 添加 数据 
通过 命令 查询 OpenLDAP 服务 器 中 数据 


13.3 通过 phpLDAPadmin 操作 LDAP 服务 器 


实例 237 
实例 238 
实例 239 
实例 240 


下 载 安装 phpLDAPadmin 工具 
添加 数据 
查看 数据 
删除 数据 


13.4 PHP 操作 LDAP 服务 器 


实例 241 
实例 242 
实例 243 
实例 244 
实例 245 
实例 246 
实例 247 
实例 248 
实例 249 
实例 250 


在 PHP 中 加 载 LDAP 

连接 、 绑 定 和 断 开 LDAP 服务 器 

查询 LDAP 目录 的 内 容 

获取 查询 结果 中 的 详细 信息 

统计 查询 结果 的 记录 数 

向 LDAP 中 添加 记录 

更 新 LDAP 中 的 记录 

删除 LDAP 中 的 记录 

获取 错误 处 理 信息 

LDAP 服务 器 实战 应 用 一 一 验证 用 户 身份 


第 14 章 PHP 与 WAP 技术 
14.1 配置 WAP 


实例 251 
实例 252 
实例 253 


Apache 中 配置 WAP 
制作 第 一 个 WAP 页 面 
WAP 页 面 跳 转 


14.2 WAP 的 应 用 


实例 254 
实例 255 
实例 256 
实例 257 
实例 258 


使 用 WAP 制作 用 户 登 录 
使 用 WAP 制作 用 户 注册 
使 用 WAP 制作 商品 信息 分 页 
站 内 查询 功能 

浏览 详细 信息 


14.3 Smarty 与 WAP 


实例 259 
实例 260 
实例 261 
实例 262 


实例 263 


实例 264 
实例 265 
实例 266 
实例 267 
实例 268 
实例 269 
实例 270 


通过 证 语句 判断 当前 用 户 的 权限 

通过 foreach 语句 读 取 数 组 中 数据 

在 模板 中 包含 子 模板 

通过 html_option 函数 向 下 拉 列 表 中 添加 
列表 项 

通过 内 建 函 数 literal 直接 在 模板 文件 中 定义 
CSS 样式 

通过 Section 循环 输出 数据 

Smarty 实现 数据 库 信息 分 页 显示 


Smarty 模板 中 时 间 的 格式 化 输出 (date_format) 


Smarty 模板 中 的 编码 〈escape[ 编 码 ]) 


Smarty 模板 中 应 用 正则 表达 式 〈regex_replace) 


Smarty 模板 中 的 关键 字 描 红 技 术 (replace) 
Smarty 模板 中 控制 输出 字符 串 的 
行 宽 (wordwrap) 


实例 271 
实例 272 
实例 273 
实例 274 
实例 275 
实例 276 
实例 277 
实例 278 
实例 279 
实例 280 
实例 281 


Smarty 模板 中 自 定义 创建 form 表单 
register_function( 方 法 注册 模板 函数 
register_object (方法 注册 模板 对 象 
在 Smarty 中 通过 truncate 方法 截取 字符 串 
Smarty 模板 制作 用 户 注册 页 面 
Smarty 模板 制作 后 台 管 理 系统 主页 
Smarty 模板 页 嵌入 JavaScript 

在 模板 中 包含 子 模板 

为 网 站 的 首先 开启 缓存 

开启 网 站 注册 页 面 的 缓存 

通过 配置 文件 定义 变量 


第 15 章 PHP 与 FTP 


15.1 
实例 282 


安装 、 配 置 Serv-U 


安装 、 配 置 Serv-U 


录 


实例 283 


连接 、 关 闭 FTP 服务 器 


15.2 操作 FTP 服务 器 


实例 284 
实例 285 
实例 286 
实例 287 
实例 288 
实例 289 
实例 290 
实例 291 
实例 292 


实例 293 
实例 294 


上 传 文件 到 FTP 服务 器 

从 FTP 服务 器 中 下 载 文件 

更 改 FTP 服务 器 中 文件 名 称 

删除 FTP 服务 器 中 指定 文件 

在 FTP 服务 器 中 创建 目录 

遍历 FTP 服务 器 指定 目录 下 文件 

文件 批量 上 传 到 FTP 服务 器 

将 指定 类 型 的 文件 上 传 到 FTP 服务 器 
将 FTP 服务 器 中 的 文件 批量 下 载 到 本 地 
计算 机 

将 制定 类 型 的 文件 下 载 到 本 地 计算 机 
查看 FTP 服务 器 指定 子 目 录 下 详细 信息 


第 3 篇 数据 库 与 抽象 层 篇 


第 16 章 “”PostgreSQL 数据 库 
16.1 PostgreSQL 数据 库 的 安装 与 操作 


实例 295 
实例 296 
实例 297 
实例 298 


16.2 通过 pgAdmin III 操作 PostgreSQL 数据 库 


实例 299 
实例 300 
实例 301 
实例 302 


PostgreSQL 数据 库 安装 
PostgreSQL 服务 的 启动 和 停止 
启动 pgAdmin II 工具 

连接 PostgreSQL 服务 器 


创建 db_database16 数据 库 

创建 tb_book 数据 表 

向 tb_book 表 中 添加 数据 

在 pgAdmin III 中 通过 SQL 语句 查询 tb_book 
表 中 数据 


16.3 PHP 操作 PostgreSQL 数据 库 


实例 303 
实例 304 
实例 305 
实例 306 
实例 307 
实例 308 


实例 309 


实例 310 
实例 311 
实例 312 
实例 313 
实例 314 
实例 315 


在 PHP 中 加 载 PostgreSQL 函数 库 

连接 、 关 闭 PostgreSQL 数据 库 
Pg_query0 函 数 执行 SQL 语句 

pg_num_rows 获取 查询 结果 集 的 记录 数 
pg_fetch_array0 函 数 将 结果 集 返 回 到 数组 中 
pg_fetch_row0 函 数 从 结果 集中 获取 一 行 作为 
枚 举 数组 
Pg_num_rows( 函 数 获取 查询 结果 集中 的 
记录 数 

Insert 语句 添加 图 书信 息 

Select 语 句 查询 图 书信 息 

分 页 显示 图 书信 息 

Update 语句 更 新 图 书信 息 

图 书信 息 的 批量 更 新 

Delete 语句 删除 图 书信 息 


实例 316 


图 书信 息 的 批量 删除 (删除 数据 前 给 予 提示 
信息 ) 


第 17 章 “SQLite 数据 库 
17.1 SQLite 数据 库 的 安装 与 配置 


实例 317 
实例 318 


下 载 SQLite 数据 库 
配置 SQLite 数据 库 


17.2 SQLite 数据 库 的 操作 


实例 319 
实例 320 
实例 321 
实例 322 
实例 323 
实例 324 


创建 db_database17 数据 库 
查看 db_database17 数据 库 
创建 tb_user 数据 表 

查看 tb_user 数据 表 

向 tb_user 数据 表 中 添加 数据 
查看 tb_user 数据 表 中 数据 


17.3 PHP 操作 SQLite 数据 库 


实例 325 
实例 326 
实例 327 
实例 328 
实例 329 


实例 330 


实例 331 
实例 332 
实例 333 
实例 334 
实例 335 
实例 336 


连接 、 关 闭 数据 库 

sqlite_query0 函 数 执行 SQL 语句 

sqlite _num_rows 获取 查询 结果 集 的 记录 数 
sqlite _fetch_array(0 函数 将 结果 集 返 回 到 数组 中 
sqlite_fetch_object 0 函数 从 结果 集中 获取 一 行 
作为 对 象 

sqlite _num_rows0 函 数 获取 查询 结果 集中 的 
记录 数 

sqlite _seek(0 查 找 指定 一 行 数据 
sqlite_rewind0 查 找 第 一 行 数据 

sqlite_next0 查找 下 一 行 数 据 
sqlite_current0 获 取 结果 集中 的 当前 行 数据 
添加 用 户 注册 信息 

用 户 登录 


实例 337 
实例 338 
实例 339 
实例 340 


PHP 开发 实战 1200 例 (第 开卷 ) 


查询 注册 用 户 

分 页 显示 注册 用 户 信息 
修改 用 户 注册 信息 
删除 注册 用 户 


第 18 章 PDO 数据 库 抽 象 层 
18.1 PDO 安装 、 配 置 


实例 341 
实例 342 


Windows 下 安装 PDO 
Linux 下 安装 PDO 


18.2 PDO 连接 数据 库 


实例 343 
实例 344 
实例 345 
实例 346 
实例 347 
实例 348 


PDO 连接 MySQL 数据 库 
PDO 连接 SQL Server 数据 库 
PDO 连接 ODBC 数据 库 
PDO 连接 Oracle 数据 库 
PDO 连接 PostgreSQL 数据 库 
PDO 连接 SQLite 数据 库 


18.3 PDO 查询 


实例 349 
实例 350 
实例 351 
实例 352 
实例 353 
实例 354 
实例 355 
实例 356 
实例 357 
实例 358 
实例 359 
实例 360 
实例 361 
实例 362 
实例 363 
实例 364 
实例 365 
实例 366 
实例 367 
实例 368 
实例 369 
实例 370 
实例 371 
实例 372 
实例 373 
实例 374 
实例 375 
实例 376 
实例 377 
实例 378 


向 图 书信 息 表 中 添加 数据 

修改 图 书信 息 表 中 的 数据 

删除 图 书信 息 表 中 的 所 有 数据 

删除 图 书信 息 表 中 的 指定 数据 

查询 字符 串 

查询 日 期 型 数据 

查询 逻辑 型 数据 

查询 非 空 数据 

利用 变量 查询 字符 串 数据 

利用 变量 查询 数值 型 数据 
查询 指定 的 N 条 记录 
查询 前 N 条 记录 

查询 后 N 条 记录 

查询 从 指定 位 置 开始 的 N 条 记录 
查询 统计 结果 中 的 前 N 条 记录 
查询 指定 时 间 段 的 数据 

按 月 查询 统计 数据 

查询 大 于 指定 条 件 的 记录 

查询 结果 不 显示 重复 记录 

NOT 与 谓词 进行 组 合 条 件 的 查询 
显示 数据 表 中 的 重复 记录 和 记录 条 数 
对 数据 进行 降序 查询 

对 数据 进行 多 条 件 排序 

对 统计 结果 进行 排序 
单列 数据 分 组 统计 

多 列 数据 分 组 统计 

多 表 分 组 统计 

使 用 聚集 函数 SUM 对 图 书 销量 进行 汇总 
使 用 聚集 函数 AVG 求 平均 每 月 的 图 书 销量 
使 用 聚集 函数 MIN 求 销售 额 、 利 润 最 少 的 
商品 


实例 379 


实例 380 


实例 381 


实例 382 
实例 383 
实例 384 
实例 385 
实例 386 
实例 387 
实例 388 
实例 389 
实例 390 
实例 391 
实例 392 
实例 393 
实例 394 
实例 395 
实例 396 
实例 397 
实例 398 
实例 399 
实例 400 
实例 401 
实例 402 
实例 403 
实例 404 
实例 405 
实例 406 
实例 407 
实例 408 


使 用 聚集 函数 MAX 求 月 销售 额 完成 最 多 的 
销售 记录 

使 用 聚集 函数 COUNT 求 日 销售 额 大 于 某 值 
的 记录 数 

使 用 聚集 函数 First 或 Last 求 数据 表 中 第 一 条 
或 最 后 一 条 记录 

使 用 from 子 句 进行 多 表 查 询 

使 用 表 的 别名 

合并 多 个 结果 集 

简单 的 嵌 套 查询 

复杂 的 嵌 套 查询 

嵌 套 查询 在 查询 统计 中 的 应 用 

使 用 子 查询 作 派生 的 表 

使 用 子 查询 作 表 达 式 

使 用 子 查询 关联 数据 

多 表 联 合 查询 

对 联合 查询 后 的 结果 进行 排序 

条 件 联合 语句 

简单 内 连接 查询 

复杂 内 连接 查询 

选择 一 个 表 中 与 另 一 个 表 中 的 行 相关 的 所 有 行 
使 用 外 连接 进行 多 表 联合 查询 

left outer join 查询 

right outer join 查询 

利用 in 或 notin 语句 限定 范围 

用 IN 查询 表 中 的 记录 信息 

由 IN 引入 的 关联 子 查询 

利用 transform 分 析 数 据 

利用 transform 动态 分 析 数据 

使 用 格式 化 函数 转换 查询 条 件 的 数据 类 型 
在 查询 中 使 用 字符 串 函数 

在 查询 中 使 用 日 期 函数 

利用 having 语句 过 滤 分 组 数据 


18.4 PDO 错误 处 理 


实例 409 
实例 410 
实例 411 
实例 412 
实例 413 


获得 查询 错误 号 

获得 查询 错误 信息 

使 用 @ 屏 项 PDO 错误 信息 

通过 异常 处 理 捕获 PDO 错误 信息 
使 用 函数 die0 打 印 错误 信息 


18.5 PDO 事务 


实例 414 
实例 415 
实例 416 
实例 417 
实例 418 


执行 一 个 批 处 理事 务 

实现 银行 安全 转账 

多 表 数 据 同时 安全 删除 
通过 事务 处 理 方式 保存 数据 
通过 事务 处 理 方式 更 新 数据 


18.6 PDO 存储 过 程 


实例 419 


通过 存储 过 程 实现 用 户 注册 


实例 420 通过 存储 过 程 实现 用 户 登录 
实例 421 通过 存储 过 程 删除 注册 用 户 
实例 422 通过 存储 过 程 修改 注册 信息 


第 19 章 ”PHPLib 数据 库 抽象 层 
19.1 PHPLib 下 载 、 安 装 
实例 423 下 载 PHPLib 
实例 424 ”使 用 require 语句 导入 PHPLib 类 库 
实例 425 ”使 用 include 语句 导入 PHPLib 类 库 
19.2 PHPLib 操作 MySQL 数据 库 
实例 426 ”向 商品 信息 表 中 添加 数据 


实例 427 
实例 428 
实例 429 
实例 430 
实例 431 
实例 432 


修改 商品 信息 表 中 的 数据 
删除 商品 信息 表 中 的 所 有 数据 
删除 商品 信息 表 中 的 指定 数据 
查询 字符 串 

查询 日 期 型 数据 

查询 逻辑 型 数据 


实例 433 
实例 434 
实例 435 
实例 436 
实例 437 
实例 438 
实例 439 
实例 440 
实例 441 
实例 442 


查询 非 空 数据 

利用 变量 查询 字符 串 数据 

利用 变量 查询 数值 型 数据 

查询 指定 的 N 条 记录 
查询 前 N 条 记录 
查询 后 N 条 记录 

查询 从 指定 位 置 开 始 的 N 条 记录 
查询 统计 结果 中 的 前 N 条 记录 
查询 指定 时 间 段 的 数据 

分 页 查询 


19.3 PHPLib 操作 Oracle 数据 库 


实例 443 
实例 444 
实例 445 
实例 446 
实例 447 


添加 留言 信息 
修改 留言 信息 
删除 留言 信息 
留言 信息 分 页 输出 
查询 留言 信息 


第 4 篇 网 站 安全 与 优化 篇 


第 20 章 ”网 站 策略 与 安全 
20.1 文件 保护 


实例 448 
实例 449 
实例 450 
实例 451 
实例 452 


防止 用 户 直接 输入 地 址 访问 PHP 文件 
防止 页 面 重复 提交 

对 查询 字符 串 进行 URL 编码 

过 滤 HTML 非法 字符 

禁止 用 户 输入 敏感 字符 


20.2 ”漏洞 防护 


实例 453 
实例 454 
实例 455 
实例 456 
实例 457 
实例 458 
实例 459 
实例 460 
实例 461 
实例 462 


防止 Access 数据 库 被 下 载 
操作 带 密码 的 Access 数据 库 
越过 表单 限制 漏洞 
文件 上 传 漏洞 

隐藏 PHP 文件 扩展 名 

通过 邮箱 激活 注册 用 户 

本 地 文件 包含 漏洞 
远程 文件 包含 漏洞 

脚本 命令 执行 漏洞 

SQL 注入 漏洞 


20.3 ”数据 加 密 


实例 463 
实例 464 
实例 465 
实例 466 
实例 467 
实例 468 
实例 469 


通过 base64 对 数据 进行 编码 

以 RFC 1738 规 则 对 URL 进行 编码 

通过 urlencode0 函 数 对 url 进行 编码 

通过 MD5 对 用 户 密码 进行 加 密 

使 用 crypt0 函 数 对 用 户 注册 密码 进行 加 密 
使 用 shal0 函 数 对 用 户 注册 密码 进行 加 密 
通过 Mcrypt 扩 展 库 对 用 户 注册 密码 进行 加 密 


实例 470 


通过 Mhash 扩展 库 对 用 户 注册 密码 进行 加 密 


20.4 身份 验证 


实例 471 
实例 472 
实例 473 
实例 474 
实例 475 
实例 476 


直接 对 用 户 的 身份 进行 验证 
通过 文本 文件 对 用 户 身份 进行 验证 
MD5 加 密 登 录用 户 名 称 和 密码 
通过 数据 库 完成 身份 的 验证 

通过 卫 验证 用 户 身份 

通过 电子 邮箱 获取 密码 


第 21 章 PHP 调试 、 升 级 与 优化 
21.1 错误 类 型 举例 


实例 477 
实例 478 
实例 479 
实例 480 
实例 481 


语法 错误 
定义 错误 
逻辑 错误 
运行 错误 
环境 错误 


21.2 程序 调试 方法 


实例 482 
实例 483 
实例 484 


应 用 DIE 语句 调试 
应 用 MYSQL_ERROR0 语 句 输出 错误 信息 
应 用 try{}catch{}M 语句 抛 出 并 捕获 异常 


21.3 ”错误 处 理 技巧 


实例 485 
实例 486 
实例 487 
实例 488 
实例 489 
实例 490 


隐藏 错误 

自 定义 错误 页 面 

延长 服务 器 执行 时 间 一 一 处 理 超时 错误 
如 何 分 析 、 解 决 PHP 与 MySQL 连接 错误 


解决 数据 库 乱 码 问题 
封装 属于 自己 的 异常 处 理 类 


PHP 开发 实战 1200 例 (第 开卷 ) 


实例 491 使 用 错误 处 理 器 记录 日 志 


实例 492 通过 mysql_error0 函 数 调试 SQL 语句 中 的 错误 


实例 493 通过 phpMyAdmin 调试 SQL 语句 中 的 错误 
21.4 PHP 优化 技巧 

实例 494 PHP 脚本 级 优化 

实例 495 ”使 用 代码 优化 工具 

实例 496 ”缓存 加 速 

实例 497 HTTP 加 速 


实例 498 ”MySQL 性 能 优化 
实例 499 MySQL 日 志 维护 
实例 500 ”数据库 外 部 优化 
实例 501 使 用 反 向 代理 

实例 502 Apache 服务 器 优化 
实例 503 ”内容 压缩 与 优化 
实例 504 分布 与 负载 均衡 


第 5 篇 框架 与 项 目 整合 


第 22 章 ThinkPHP 框架 

22.1 ThinkPHP 的 MVC 环境 搭建 
实例 505 环境 配置 
实例 506 框架 结构 
实例 507 创建 流程 

22.2 ThinkPHP 的 MVC 操作 
实例 508 ”URL 访问 
实例 509 ThinkPHP 控制 器 
实例 510 ThinkPHP 视图 
实例 511 ThinkPHP 模型 

22.3 ThinkPHP 的 访问 数据 库 
实例 512 ”连接 MySQL 数据 库 
实例 513 用 户 注册 
实例 514 用 户 登录 
实例 515 ”发 布 信息 
实例 516 ”查询 信息 
实例 517 修改 信息 
实例 518 删除 信息 
实例 519 信息 分 页 显示 


第 23 章 Zend Framework 框架 
23.1 Zend Framework 的 MVC 环境 搭建 
实例 520 环境 配置 
实例 521 框架 结构 
实例 522 ”创建 流程 
实例 523 ”Zend Framework 的 编码 标准 
23.2 Zend_Layout 网 站 布局 
实例 524 Zend_Layout 对 站 点 进行 布局 
实例 525 ”通过 Zend_Layout 对 博客 的 页 面 进行 布局 
23.3 ”Zend_Config 配置 文件 
实例 526 ”Zend_Config 配置 站 点 初始 参数 
实例 527 根据 Zend_Config_Ini 配置 站 点 初始 参数 
23.4 Zend_Cache 缓存 服务 
实例 528 ”Zend_Cache 对 数据 库 中 信息 缓存 输出 
实例 529 通过 Zend_Cache 删除 缓存 


XXIV 


23.5 Zend_Paginator 分 页 

实例 530 ”Zend_Paginaator 实现 数据 分 页 显示 

实例 531 通过 修改 样式 做 成 下 拉 菜 单 分 页 
23.6 Zend_Form 分 页 

实例 532 ”Zend_Form 制作 用 户 注册 表单 

实例 533 ”使 用 Zend_Form 制作 用 户 登 录 页 面 
23.7 Zend_Auth 身份 认证 

实例 534 ”Zend_Auth 对 用 户 身 份 进行 验证 

实例 535 通过 Zend_Auth 验证 用 户 名 是 否 被 注册 
23.8 Zend_Acl 权限 管理 

实例 536 ”通过 Zend_Acl 控制 角色 和 资源 的 权限 

实例 537 通过 Zend_Acl 完成 精细 的 访问 权限 控制 
23.9 Zend_Db 数据 库 操作 

实例 538 ”Zend_Db_Adapter 数据 库 操作 

实例 539 Zend_Db_Table 数据 库 操作 

实例 540 数据 表 类 
23.10 Zend_File 文件 控制 

实例 541 使 用 Zend_File_Transfer_Adapter_Http 实现 

POST 方式 文件 上 传 
实例 542 对 上 传 文件 的 合理 性 验证 
实例 543 ”为 上 传 增加 过 滤 规 则 


第 24 章 新 闻 发 布 系统 (ThinkPHP) 
24.1 数据 库 设计 
实例 544 创建 数据 库 
实例 545 ”创建 数据 表 
24.2 MVC 框架 结构 搭建 
实例 546 ThinkPHP 框架 的 MVC 目录 结构 
实例 547 ThinkPHP 框架 的 MVC 结构 创建 过 程 
24.3 前台 设计 
实例 548 前 台 首页 设计 
实例 549 ”新闻 分 页 输出 
实例 550 ”新闻 浏览 
实例 551 站 内 搜索 一 一 使 用 空格 分 隔 多 关键 字 
实例 552 关键 字 描 红 


实例 553 ”隐藏 PHP 文件 后 绥 一 一 伪 静 态 技术 
24.4 ”后台 管理 设计 

实例 554 管理 员 登 录 

实例 555 新闻 管理 

实例 556 用户 管理 

实例 557 退出 登录 


第 25 章 ”明日 搜索 引擎 (Zend_Framework) 
25.1 数据 库 设计 
实例 558 创建 数据 库 
实例 559 创建 数据 表 
25.2 MVC 框架 结构 搭建 
实例 560 ”Zend_Framework 框架 的 MVC 目录 结构 
实例 561 Zend_Framework 框架 的 MVC 结构 创建 过 程 
25.3 前台 设计 
实例 562 首页 设计 


实例 563 
实例 564 
实例 565 
实例 566 
实例 567 
实例 568 
实例 569 
实例 570 
实例 571 
实例 572 


25.4 后 台 


实例 573 
实例 574 
实例 575 
实例 576 


用 户 注册 

用 户 登 录 

发 表 问 题 

回复 问题 
查询 结果 的 分 页 输出 
验证 码 生 成 

类 似 Google 搜索 引擎 的 搜索 条 
使 用 空格 分 隔 多 关键 字 
关键 字 描 红 
制作 在 线 编辑 器 
设计 

后 台 管理 员 登 录 

用 户 管理 

用 户 查 询 

退出 登录 


基础 篇 


让 第 1 章 开发 环境 
WH 第 2 章 PHP 基础 
WH 第 3 章 Web 页 面 交 互 


训 


第 [人 s 


ag 
ag 
Ph 
Ph 
Ph 
Ph 


ag 


AppServ 一 一 PHP 集成 化 安装 包 
XAMPP 一 一 PHP 集成 化 安装 包 
lIS+PHP+MySQL 一 一 独立 搭建 PHP 开发 环境 
LAMP 一 一 独立 配置 PHP 开发 环境 
XAMPP 一 一 Linux 版 PHP 集成 化 安装 包 
Dreamweaver 开发 工具 

Zend Studio 开发 工具 


开发 环境 


第 1 章 开发 环境 


1.1 AppServ 一 一 PHP 集成 化 安装 包 


AppServ 将 Apache、PHP、MySQL 和 phpMyAdmin 等 服务 器 软件 和 工具 安装 配置 完成 后 进行 打包 处 理 ， 开 
发 人 员 只 要 到 网 站 上 下 载 该 软件 ， 然 后 安装 ， 即 可 完成 PHP 开发 环境 的 快速 搭建 ， 非 常 适合 初学 者 使 用 。 


实例 说 明 
在 本 实例 中 ， 讲 解 如 何 通过 AppServ 配置 PHP 的 开发 环境 ， 配 置 完 成 后 将 输出 如 图 1.1 所 示 的 页 面 。 
S510 Setup 0 sl‘| 
Completing the AppServ 2.5.10 
tup Wizard 
Eerie 
BB sarmWsQL 
| 
图 1.1 PHP 开发 环境 配置 完成 
图 关键 技术 


通过 AppServ 配置 PHP 开发 环境 时 ， 首 先 从 互联 网 上 下 载 AppServ 的 安装 文件 ， 下 载 地 址 为 
http://www.AppServnetwork.com/。 


A 注意 : 在 使 用 AppServ 搭建 PHP 开发 环境 时 ， 必 须 确保 在 系统 中 没有 安装 Apache、PHP 和 MySQL.。 否则 ， 
要 先 将 这 些 软件 印 载 ， 然 后 应 用 AppServ。 


在 软件 的 安装 过 程 中 ， 要 重点 注意 下 面 儿 个 步骤 : 
设置 安装 路 径 ; 

选择 安装 软件 ; 

设置 端口 号 ; 

设置 数据 库 密码 ; 

设置 数据 库 编码 格式 。 


图 设计 过 程 
下 面 对 应 用 AppServ 集成 化 安装 包 拱 建 PHP 开发 环境 的 具体 操作 步骤 进行 讲解。 


(1) 双击 AppServ-win32-2.5.10.exe 文件 ， 打 开 如 图 1.2 所 示 的 AppServ 启动 页 面 。 
(2) 单 击 图 1.2 中 的 Next 按钮， 打开 如 图 1.3 所 示 的 AppServ 安装 协议 页 面 。 


办 办 国名 
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Welcome io the AppServ2 5 10 
Setup Wizard 


3 本 
license Agreement 
Mease revien the herse terms before rstdling AppSer 2.5.10, 


The vizard wil gude you frouch the nstalation of ApgSery Press ?a0e Down to see tre est of the aoreenent 
25.10. 
It recammerded that you dose al other spok 


GN LESSER GEVERAL PUBLIC LICENSE 习 
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relevant system fles withouthaving th rebaot your |Copyright IC) 1931, 1995 Free Software Foundation, 

Click Next to continue, of ene out changrg itis not aloned. 
ne s he frst relessed verson of tre Lesser GR.. Htabo courts 
[Re een er 
[Et 可 
eh 
rt sl ose 2 


Mb rota syaer ye, 


Esel 
图 1.2 AppServ 启动 页 面 
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图 1.3 ”AppServ 安装 协议 
(3) 单 击 图 1.3 中 的 IAgree 按钮 ， 打 开 如 图 1.4 所 示 的 页 面 。 设置 AppServ 的 安装 路 径 〈 默 认 安 装 路 径 一 
般 为 C:\AppServ) ，AppServ 安装 完成 后 ，Apache、MySQL、PHP 都 将 以 子 目 录 的 形式 存储 到 该 目录 下 。 
(4) 单 击 图 1.4 中 的 Next 按钮 ， 打 开 如 图 1.5 所 示 的 页 面 ， 选 择 要 安装 的 程序 和 组 件 〈 默 认为 全 选 ) 。 


(Choose Install Localion 
Choose the folder in whicn to instal AooServ 2.5.10, 


Select Components 
Subp wl petol ppbery 2 10m tre ehowng Se Toinetal ns dfferene fdr, dk 
Erowse and select mather foder, Cick Next 0 cntnue. 


Select the corponerts you wantio neial cear the components 
L 和 
Ev Appeerv radage Conponente 
本 | 
eal FF MysQ Datasaee 
Space required: 56,4MB pe ere 
Space avalable: 3.668 
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1.4 AppServ 安装 路 径 选择 


图 1.5 AppServ 安装 选项 
@g 技巧: 在 第 (4) 步 中 ， 如 果 本 机 已 经 安装 MySQL 数据 库 ， 那 么 可 以 不 义 选 MySQL Database 选项 ， 仍 使 


用 本 机 已 经 存在 的 MySQL 数据 库 。 
(5) 在 图 1.5 中 单 击 Next 按钮 ， 打 开 如 图 1.6 所 示 的 页 面 。 填写 计算 机 名 称 、 添 加 邮箱 地 址 、 设 置 Apache 
的 端口 号 (默认 为 80 端口 ) 。 


Server Nane (eg. ww.appsevnetort. cem) 


pe 计算 机 名 称 
Administrator's Email 2ddress (e.g. webrasier gnal.com) 
Frame pe 
Moee TTP Port Defat 50 . 

pe — 


Moft Irstall S/stam v2.13 


es EE oe 


图 1.6 Apache 端口 号 设置 
< 注意 : Apache 服务 器 端口 号 的 设置 ， 直 接 关系 到 Apache 服务 器 是 否 能 够 正常 启动 。 如 果 本 机 中 的 80 端口 
被 IIS 或 者 迅雷 占用 ， 那 么 这 里 就 需要 修改 Apache 的 端口 号 ， 或 者 修改 IIS 和 迅雷 的 端口 号 ， 才 能 
完成 Apache 服务 器 的 配置 。 如 果 出 现 端口 冲突 ， 那 么 将 导致 安装 失败 ，Apache 服务 不 能 启 
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(6) 单 击 图 1.6 中 的 Next 按钮 ， 打 开 如 图 1.7 所 示 的 页 面 。 设置 MySQL 数据 库 root 用 户 的 登录 密码 及 字 


说 明 : MySQL 数据 库 的 字符 集 , 可 以 设置 为 UIF-8、GBK 或 者 GB2312 格式 。 这 里 将 字符 集 设置 为 “GB2312 


Simplified Chinese”， 表 示 MySQL 数据 库 的 字符 集 将 采用 简体 中 文 形式 。 
Ea 


厂 od Posewerd support PrP MYSQL Api fncton) 
Enabe neoe 


Mulsoft Iretal systam v2 Ia 


waal 
1.7 设置 MySQL 数据 库 root 用 户 的 密码 和 字符 集 


29 技巧 ， 对 于 在 图 1.7 中 设置 的 MySQL 数据 库 root 用 户 的 密码 必须 牢记 ， 因 为 程序 在 连接 数据 库 时 必须 使 
用 这 个 密码 。 建 议 读者 将 这 个 密码 设置 为 111, 因 为 这 是 在 开发 本 书 中 的 程序 时 所 使 用 的 数据 库 密 码 。 
如 此 ， 在 运行 本 书 中 的 数据 库 程序 时 ， 就 不 需要 修改 密码 ， 否 则 要 修改 连接 数据 库 的 密码 。 如 果 忘 
记 安 装 时 设置 的 密码 ， 最 直接 有 效 的 解决 方式 是 重新 安装 AppServ。 


(7) 单 击 图 1.7 中 的 Install 按钮 ， 开 始 安装 ， 如 图 1.8 所 示 。 
(8) 安装 完成 后 可 以 在 开始 菜单 的 AppServ 相关 操作 列表 中 启动 Apache 及 MySQL 服务 ， 如 图 1.9 所 示 。 
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1.8 AppServ 安装 页 面 图 1.9 AppServ 安装 完成 页 面 


图 秘笈 心 法 


心 法 领悟 001: Apache 的 配置 文件 。 
Apache 的 配置 文件 存储 于 C:\AppServ\Apache2.2\conf\httpd.conf。 通过 Apache 配置 文件 可 以 设置 Apache 的 
端口 号 、Apache 服务 器 的 根 目录 或 者 控制 Apache 是 否 支 持 伪 静 态 。 
(1) 设置 Apache 的 端口 号 : 
Listen 80 


(2) 设置 Apache 服务 器 的 根 目录 : 


PHP 开发 实战 1200 例 (第 I 卷 ) 
DocumentRoot "C:/AppServ/www" 


(3) 设置 对 伪 静 态 的 支持 : 


机 oadModule rewrite_module modules/mod rewrite.so 

将 该 项 前 面 的 “#” 去 掉 ， 可 启动 该 项 。 查 找 httpd.conf 文件 ， 找 到 其 中 的 “AllowOverride” 项 ， 将 其 值 都 
修改 为 All。 

完成 对 Apache 的 修改 后 ， 必 须 保 存 文件 ， 并 重新 启动 Apache 服务 器 才能 够 生效 。 


中 级 | 
趣味 指数 :从 人 全 而 


实例 002 


图 实例 说 明 
安装 AppServ 后 ， 可 以 对 其 进行 测试 。 在 正 浏 览 器 的 地 址 栏 中 输入 hppt://127.0.0.1， 如 果 输 出 如 图 1.10 所 


The AppServ Open Project - 2.5.10 for Windows | 


乳 phpMyAdmin Database Manager Version 2.10.3 
2) PHP Intormation Version 5.2.6 


AppSevis a meigng open source sofwere installer package forWindows 
includes 


+» Apache Web Server Version2.2.8 

，PHP Script Language Varsion5.2.6 

，MySQL Database Vericn 5.0.51b 

+ phpMyAdmin Database Manager Version2.10.3 


图 1.10 PHP 开发 环境 配置 成 功 


图 关键 技术 
AppServ 安装 完成 后 ， 整 个 目录 默认 安装 在 CAppServ， 此 目录 下 包含 4 个 子 目 录 ， 如 图 111 所 示 ， 用 户 
可 以 将 所 有 程序 文件 存储 到 www 目录 下 。 


a 
HD Apacdhe2.2 Apache 的 存储 目录 
Ws SQL 的 存储 目录 
外 ps PIT 的 存储 路 径 
四 加 ww 网 页 文件 及 phplykdnin 的 存储 路 径 


图 1.11 AppServ 目录 结构 


在 Apache2.2\conf\ 目 录 下 ， 有 一 个 httpd.conf 文件 ， 它 是 Apache 服务 器 的 配置 文件 ， 在 这 个 文件 中 可 以 修 
改 Apache 服务 器 的 端口 号 、 根 目录 等 ， 所 有 有 关 Apache 服务 器 的 配置 都 在 这 个 文件 中 完成 。 
在 MySQL 目录 下 ， 有 一 个 my.ini 文件 ， 它 是 MySQL 服务 器 的 配置 文件 ， 存 储 MySQL 的 配置 信息 。 
在 MySQLAdata 目录 下 存储 的 是 数据 库 文 件 ， 所 有 程序 使 用 的 数据 库 都 存储 在 这 个 文件 夹 下 。 
说 明 : 如 果 MySQL 服务 器 的 版 本 是 5.1， 那 么 数据 库 文件 夫 data 的 默认 存储 位 置 是 C:/Documents and 
Settings/All Users/Application Data MySQL/MySQL Server 5.1/Data/. 
在 php5\ext 文 件 夹 下 存储 的 是 PHP 内 置 的 函数 类 库 ,以 .dll 的 格式 存储 。 而 PHP 的 配置 文件 php.ini 存储 在 


本 机 系统 盘 的 windows 文件 夹 下 。 
www 目录 是 程序 运行 的 根 目 录 ， 也 就 是 说 我 们 要 运行 的 所 有 程序 都 必须 存储 在 这 个 目录 下 。phpMyAdmin 
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图 形 化 管理 工具 默认 存储 在 此 目录 下 。 
图 设计 过 程 
(1) www 文件 夹 存储 网 站 的 运行 文件 ， 其 默认 的 内 容 如 图 1.12 所 示 。 


=lslx 

文件 如 编 笑 局 过 看) 收 这 ) 工具 C) 加 助人 ) | 和 
天 生男 后 wmserwm EE 

3 I 大小 | 区 型 [ERE 风 | 
已 msev 伞 天 
局 :aun 
Bsn 
lp] phpinfo. php 
1 到 
展开 : 7 fle 修改 日 央 2010-0-25 1|10 字 节 ”|[ 子 我 的 电 廊 网 


图 1.12 www 文件 夹 的 默认 内 容 


(2) 其 中 ,index.php 是 默认 访问 127.0.0.1 时 浏览 的 内 容 ; 而 phpinfo.php 存储 的 是 PHP 的 配置 信息 和 支持 
的 模块 。phpinfo.php 的 内 容 如 图 1.13 所 示 。 


System PS Bt Wn re rr rd A) 
Build Date |Nov 20 2009 17:20:57 

Compiler IMSVCS weua c++ 5.0) 

Architecture |x86 


Configure Command Icscrpt /nologo configure Js “enable-snapshotbuld” 
Server API |spache 2.0 Hander 
Virtual Directory Support |enabled 


图 1.13 phpinfo.php 的 内 容 
(3) 其 中 的 phpMyAdmin 文件 夹 存储 的 是 phpMyAdmin 图 形 化 管理 工具 。 
力 秘笈 心 法 


心 法 领悟 002: AppServ 的 相关 说 明 。 

(1) 如 果 是 应 用 AppServ 配置 的 PHP 开发 环境 ， 那 么 在 正 浏览 器 中 直接 输入 127.0.0.1 将 输出 如 图 1.10 
所 示 的 页 面 ， 因 为 在 www 文件 夹 下 有 一 个 默认 的 index.php 文件 ， 如 果 要 运行 www 文件 夹 下 的 其 他 文件 ， 那 
么 必须 在 127.0.0.1 后 指定 具体 的 文件 夹 或 者 文件 ， 例 如 ， 输 入 127.0.0.1/text.php 或 者 127.0.0.1/mr/。 

(2) Apache 的 启动 和 停止 

单 击 “ 开 始 ” 按 钮 ， 选 择 “ 程 序 ”/AppServ/Control Server by Service 命令 ， 在 弹出 的 菜单 中 完成 Apache、 
MySQL 服务 器 的 启动 和 停止 操作 。 

单 击 “ 开 始 ”按钮 ， 选 择 “ 设 置 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ”命令 ,找到 Apache2.2， 单 击 右键 ， 
完成 Apache 的 启动 、 停 止 或 者 重新 启动 操作 。 

完成 对 php.ini 文件 的 修改 后 ， 同 样 要 保存 文件 ， 重 新 启动 Apache 服务 器 后 ， 修 改 才能 够 生效 。 


实例 003 初 妥 | 


力 实例 说 明 
AppServ 安装 、 调 试 成 功 后 ， 开 发 第 1 个 PHP 程序 ， 输 出 系统 的 当前 时 间 ， 运 行 结果 如 图 1.14 所 示 。 
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tte://127.0.0. 1/mr /O110037 122 x| 
文件 四 转 各 四 查看 轨 “ 收 意 内 工具 WD) 4” 名 | 
殉国 峰 wtewir on ye/too/ 梧 回 ESER 本 


2010-06-26 07:30:53 
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图 1.14 第 1 个 PHP 程 序 


图 关键 技术 


(1) 应 用 PHP 中 的 date 函数 ， 输 出 系统 的 当前 时 间 ， 设 置 时 间 的 格式 为 年 -月 -日 时 : 分 : 秒 (Y-mdHis) 。 

(2) 将 编写 的 mdex.php 文件 存储 于 www 文件 夹 下 的 MR\01\003 目录 下 。 

在 运行 本 实例 时 , 会 发 现 程序 输出 的 时 间 与 系统 的 当前 时 间 相差 了 8 个 小 时 ， 至 于 为 什么 会 出 现 此 种 情况 ， 
我 们 将 在 本 实例 的 秘笈 心 法 中 讲解 。 


图 设计 过 程 
(1) 通过 Dreamweaver 创建 一 个 index.php 脚本 文件 ， 存 储 于 MR/01/003/ 文 件 夹 下 。 
(2) 应 用 date0 函 数 输出 系统 的 当前 时 间 ， 其 代码 如 下 : 
ee /输出 系统 的 当前 时 间 
> 
(3) 在 正 浏览 器 中 输入 http://127.0.0.1/mr/01/003/， 运 行 结果 如 图 1.14 所 示 。 
岂 笈 心 法 
心 法 领悟 003: 对 于 系统 时 间 的 相关 说 明 。 
程序 输出 时 间 与 系统 当前 时 间 出 现 偏差 的 关键 是 php.ini 文件 的 设置 。 在 php.ini 文件 中 , 默认 设置 的 是 标准 
的 格林 威 治 时 间 ， 即 采用 的 是 英国 伦敦 时 间 ， 而 我 们 的 当地 时 间 是 北京 时 间 ， 所 以 会 出 现时 间 的 偏差 。 
PHP 的 配置 文件 存储 于 C:\WINDOWS\php.ini 文件 中 。 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone 
=” 选 项 ,去掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当地 所 在 时 区 使 用 的 时 间 ， 即 可 统一 程序 输出 的 时 间 与 系统 当前 的 
时 间 。 
:date.tfimezone = 
例如 ， 如 果 当 地 所 在 时 区 为 东 八 区 ， 那 么 就 可 以 设置 date.timezone 的 值 为 PRC、Asia/Hong Kong、Asia/ 
Shanghai (上 海 ) 或 者 Asia/Urmmqi (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


1.2 XAMPP 一 一 PHP 集成 化 安装 包 


XAMPP (Apache+MySQL+PHP+PERL ) 是 一 个 功能 强大 的 建站 集成 软件 包 , 可 以 在 Windows、 Linux、Solaris 
3 种 操作 系统 下 安装 使 用 ， 支 持 多 种 语言 ， 包 括 英文 、 简 体 中 文 、 繁 体 中 文 、 韩 文 、 俄 文 、 日 文 等 。 


趣味 指数 ， 斌 请 寅 家 : 


图 实例 说 明 


XAMPP 是 一 个 易于 安装 且 包 含 MySQL、PHP 和 Perl 的 Apache 发 行 版 。 安 装 成 功 后 的 运行 效果 如 图 1.15 
所 示 。 


第 1 章 开发 环境 


文件 个” 蝙 加 四。 查看 W) 收 训 全 ”工具 中 ”帮助 名 
0 nero 


XAMPP for Windows 


XAMPP 1.7.3! 
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图 1.15 XAMPP 安装 成 功 


图 关键 技术 


目前 XAMPP 的 Windows 版 本 是 1.7.3， 包 括 如 下 内 容 : 
Apache 2.2.14 (IPVv6 enabled) 

MySQL 5.1.41 + PBXT engine 

PHP 5.3.1 

OpenSSL 0.9.81 

phpMyAdmin 3.2.4 

XAMPP Control Panel 2.5.8 

XAMPP CLI Bundle 1.6 

‘Webalizer 2.21-02 

Mercury Mail Transport System v4.72 
msmtp 1.4.19 

FileZilla FTP Server 0.9.33 

SQLite 2.8.17 

SQLite 3.6.20 

ADOdb 5.10 

eAccelerator 0.9.6-rcl 

Xdebug 2.0.6-dev 

Ming 0.4.3 

适用 于 Windows 2000/XP/2003/Vista/7。 

在 Windows 操作 系统 下 ，XAMPP 有 两 种 形式 : 
自 解压 RAR 包 : 简单 且 安 全 。 

回 ZP 压缩 包 : XAMPP 的 普通 ZIP 压缩 档案 。 


图 设计 过 程 


XAMPP 1.7.3 版 的 具体 安装 步骤 如 下 : 


因 办 办 办 办 办 办 因 办 办 因 因 办 办 多 


加 
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(1) 运行 .exe 安装 文件 ， 将 弹出 如 图 1.16 所 示 的 操作 界面 ， 在 这 里 设置 XAMPP 的 安装 路 径 。 
(2) 安装 路 径 设 置 完成 后 ， 单 击 Install 按钮 ， 执 行 XAMPP 的 安装 ， 如 图 1.17 所 示 。 


画 XAMPP for wndows =|Glx| 而 xAmpp for windows jsjxl 


assz>xg 


Dearaionfaker 
区 避 [Ces 
a 
图 1.16 设置 XAMPP 的 安装 路 径 图 1.17 安装 XAMPP 
(3) XAMPP 安装 成 功 后 ， 将 弹出 如 图 1.18 所 示 界面， 在 其 中 对 XAMPP 进行 设置 ， 包 括 是 否 创建 


桌面 快捷 方式 、 是 否 在 开机 时 启动 XAMPP 等 。 
=| 昌 | 


拉 提 拉 提 和 拉 拉 持 持 拉 拉 拉 拉 拉 和 村 和 和 和 拉 拓 和 拉 拉 拉 拉 拓 所 拉 拉 拉 拉 村 拉 打 和 和 和 拉 拓 和 拉 拉 和 持 持 和 科 村 科 拉 拉 拉 村 拉 拉 持 和 拉 拉 持 村 
# XAMPP 1.7.3 — Setup 划 


图 1.18 设置 XAMPP 


至 此 ，XAMPP 的 安装 、 配 置 完毕 。 
图 秘笈 心 法 

心 法 领悟 004: XAMPP 中 的 配置 文件 。 

XAMPP 中 各 种 配置 文件 的 存储 位 置 如 下 : 
Apache 基本 配置 : .\xampp\apache\conf\httpd.conf 
Apache SSL: .\xampp\apache\conf\ssl.conf 
Apache Perl 〈 仅 限 插件 ) : .\xampp\apache\conf\perl.conf 
PHP: .\xampp\php\php.ini 
MySQL: .\xampp\mysql\binmy.ini 
phpMyAdmin: .\xampp\phpMyAdmin\config.inc.php 
FileZilla FTP 服务 器 : .\xampp\FileZillaFTP\FileZilla 


国 办 办 国 国 多 
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初级 


实例 005 趣味 指数 : Ne 


图 实例 说 明 


成 功 安装 XAMPP 后 ， 启 动 Apache 服务 器 ， 在 浏览 器 的 地 址 栏 中 输入 http://localhost 或 http://127.0.0.1， 
即 可 检测 所 有 的 XAMPP 样 例 和 工具 ， 运 行 结果 如 图 1.19 所 示 。 


2 Wa A5Y Wm) IAD TO 
Er er 


XAMPP 1.7.31 
on: 

3 sense Tp 

天 下 人 可 以 开间 A0 ch 以 有 本 作 和 入 可 二 在 仙 的 5 寺 革 上 的 羽 机 世 时 本 要 和 

DER 

SAT he A510neysot 4 让 Wvboter 

win32 要 本 笑 代 的 补 了 1 


ret Https .11127.0.0.4 R$ tpsallacahest 和 还 OpensSL 


图 1.19 检测 安装 是 否 成 功 


力 关键 技术 


XAMPP 中 默认 将 所 有 网 络 文档 存储 于 htdocs 主 文件 夹 中 〈.\xampp\htdocs) 。 默 认 htdocs 主 文件 夹 下 的 内 
容 如 图 1.20 所 示 。 


文件 妇 ”入 过 开 旭 咎 WW 路 守 向 I 上 IU) 吉 的 ” 需 
[Er 司 


图 1.20 XAMPP 的 默认 网 络 文件 


读者 可 以 在 浏览 器 的 地 址 栏 中 输入 http:/localhost 来 检测 XAMPP 是 否 安装 成 功 。 
图 设计 过 程 
(1)XAMPP 文件 夹 存储 的 是 XAMPP 的 各 种 配置 信息 , 当 直 接 运 行 index.php 文件 时 ,调用 的 就 是 XAMPP 


文件 夹 下 的 index.php 文件 ， 输 出 如 图 1.20 所 示 的 内 容 。 
(2) 在 index.html 文件 中 ， 输 出 一 个 简单 的 测试 信息 ， 如 图 1.21 所 示 。 


ol Dy 
上 | -EE 
tw /er 0.0 Vinee vol 本 | 回 
It works! 引 
BE FE 厂 可 5 加 


1.21 通过 html 测试 PHP 是 否 安装 成 功 


加 


PHP 开发 实战 1200 例 (第 I 卷 ) 
(3) 在 index.php 文件 中 ， 通 过 header0 函 数 跳 转 到 xampp 文件 夹 下 的 index.php， 输 出 XAMPP 的 信息 。 
图 秘笈 心 法 


心 法 领悟 005: 如 何 启 动 、 停 止 和 测试 XAMPP。 
通过 文件 xampp\xampp-controlexe 控制 XAMPP 的 启动 、 停 止 和 测试 。 


实例 006 


图 实例 说 明 

XAMPP 只 为 开发 者 服务 ,切记 不 要 将 其 应 用 于 生产 环境 ， 因 为 对 于 生产 环境 而 言 ， 使 用 XAMPP 可 能 会 带 
来 灾难 性 的 打击 。 

因为 MySQL 管理 员 (root) 未 设置 密码 ， 用 户 可 以 直接 通过 phpMyAdmin 访问 MySQL 服务 器 ， 修 改 数据 
库 中 的 数据 ， 或 者 通过 网 络 访问 ， 运 行 结果 如 图 1.22 所 示 。 


到 127 0.0.1 / lecslhest / phpsyadain | phplyAdnin 3 2 e007 
文件 四 编 手 @) 查看 由 收 蕊 @) 工具) 开 助 只 a 
地 三 | 全 http//127 0 0 1/ptpaysininVinder php7ab=ecdeolatoken-ovzbeeldubazz] [有 -和 


phpMyAdmin | 里 服务 器 : localhost 成 数据 库 : phpmyadmin 


呵 结 构 “ 避 SOL 万 搜索 各 查 徊 ”总 叶 出 
包 国 后 白 _ 配 导入 吧 设 计 秋 。 短 操 作 。 的 权限 “中 开除 
EE 各 人 


数据 库 
phpmyadmin (6) 了 


厂 。 pma_bookmark | 总 
» 


| [三 |@ 5 人 站 点 到 


图 1.22 直接 访问 MySQL 数据 库 


力 关键 技术 

要 确保 MySQL 数据 库 的 安全 ， 必 须 为 MySQL 管理 员 (root) 设置 密码 ， 其 方法 如 下 : 

以 root 用 户 的 身份 登录 phpMyAdmin， 在 phpMyAdmin 的 权限 中 设置 root 用 户 的 密码 。 操 作 界 面 如 图 1.23 
所 示 。 


中 服务 器 : localhost 
_ 必 数据 库 ， 丸 SQL 韶关 态 ” 国 变量 加 字符 集 、 凯 引 擎 、 仿 权限 “局 进程 。 范 导 出 。 面 导 入 
多 编辑 权限 : 用 户 root@ocalhost 
广 你 改 室 码 
人 无 名 三 
6 多 [rr rr 
窗 码 0 密 方式 。 G MySQL4 1+ 

个 兼容 MySQL40 
生成 至 码 生成 


Ed 


图 1.23 修改 MySQL 用 户 密码 
说 明 : 更 改 root 的 密码 之 后 ， 还 要 修改 phpMyAdmin 中 的 相关 信息 ， 具 体 方法 请 参看 设计 过 程 。 
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图 设计 过 程 

在 phpMyAdmin 的 权限 中 完成 root 用户 的 密码 设置 后 ,在 \.\xampp\phpmyadmin\ 下 搜索 config.inc.php 文件， 
定位 到 如 下 位 置 : 

/* Authentication type and info */ 

S$cfe['Servers'"][$i]['auth_type] = http'; // 设 置 登录 方式 

Scfe['Servers"][$il[user] ='Toot; /设置 用 户 名 

Scfe[Sservers][sSil[password] ="111; /设置 密码 

S$cfg['Servers'][$Si]['AllowNoPassword'] = true; 


设置 auth type 的 值 为 “http”; 设置 password 的 值 为 “111”， 这 样 登录 phpMyAdmin 时 ， 就 必须 要 输入 
密码 ， 否 则 无 法 登录 。 
图 秘笈 心 法 

心 法 领悟 006: 修改 MySQL 缺 省 字符 集 。 

修改 MySQL 缺 省 字符 集 为 utfg， 定 位 到 my.ini 文件 ， 需 添加 如 下 内 容 : 


[client] 
default_character set=utf8 


[mysqld] 

# default-character-set=utf8 
character-set-server = utf8 
collation-server = utf8_general_ci 
[mysqll 

default_character set=utf8 


初级 | 
趣味 指数 : 突 穴 页 认 


实例 007 


图 实例 说 明 


既然 XAMPP 只 为 开发 者 服务 ， 那 么 我 们 就 应 用 XAMPP 开发 一 个 PHP 程序， 熟悉 一 下 XAMPP 的 应 用 。 


本 实例 简单 地 输出 一 段 文字 ， 其 运行 结果 如 图 1.24 所 示 


| mas 2010 年 6 月 28 昌 oa 号 
加 


BE OW 


1.24 第 2 个 PHP 程 序 


图 关键 技术 


(1) 确定 服务 器 的 运行 文件 夹 ， 编 写 PHP 脚本 文件 ， 将 其 存储 于 XAMPP 指定 的 运行 文件 夹 下 。 
(2) 应 用 PHP 的 date0 函 数 输出 系统 的 当前 时 间 ， 时 间 的 格式 是 “年 月 日 时 分 秒 ”。 


图 设计 过 程 
(1) 新 建 一 个 记事 本 文件 ， 编 写 PHP 脚本 ， 通 过 date0 函 数 输 出 系统 的 当前 时 间 ， 其 代码 如 下 : 
ee "date("Y 年 m 月 d 日 HH 时 i 分 s 秘 "); 


(2) 保存 这 个 记事 本 文件 ， 将 其 存储 于 xampp\htdocs\MR\01\007( 这 是 笔者 在 本 机 中 定义 的 实例 存储 文 
特 正 s 
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图 秘笈 心 法 

心 法 领悟 007: 如 何 配置 默认 的 开始 页 面 ? 

如 果 在 浏览 器 地 址 栏 中 输入 http://localhost/xampp/, Apache 服务 器 会 自动 返回 一 个 默认 的 开始 页 面 , Apache 
会 自动 寻找 已 存在 的 类 似 index.php 的 索引 页 。httpd.conf 中 的 “DirectoryIndex” 指 令 负责 这 个 功能 。 在 这 里 可 
以 定义 默认 开始 页 面 的 名 字 和 协议 。 


XAMPP 在 默认 状态 下 ，“DirectoryIndex” 指 令 的 列表 如 下 : 
index php index.php4 index.php3 index cgi index plindex html index htm index htmlvarindex phtml 


1.3 IIS+PHP+MySQI 一 一 独立 搭建 PHP 开发 环境 


Internet 信息 服务 器 即 Internet Information Server, 缩写 为 JS, 是 Microsoft 的 Web 服务 器 。 它 集成 于 Windows 
NT Server 之 中 ， 方 便 易 用 ， 为 Web 应 用 程序 提供 了 功能 强大 的 运行 平台 。 

本 书 使 用 HS 6.0， 在 Windows 2003 操作 系统 下 完成 PHP 环境 的 搭建 ， 所 使 用 的 软件 包括 : 

回 PHP 软件 : php-5.3.1-nts-Win32-VC9-x86 

回 ”MySQL 数据 库 : mysql-essential-5.1.39-win32.msi 


[ED 说明: 上 述 版 本 是 笔者 在 开发 本 书 时 所 使 用 的 ,读者 可 以 根据 自己 的 实际 情况 进行 调整 。 如 果 是 Windows 7 
操作 系统 ， 则 使 用 JIS 7.0， 如 果 是 Windows XP 系统 ， 则 使 用 IIS 5.0。 


实例 008 wo 


08 趣味 指数 : 依依 依从 | 


力 实例 说 明 


PHP 5.3.1 是 PHP 目前 推出 的 最 新 版 本 ， 可 以 到 PHP 的 官方 网 站 下 载 ， 下 载 地 址 为 http: Wwww.php.net/ 
downloads.php。 
本 实例 讲解 如 何 选择 、 安 装 PHP 5.3.1。 
图 关键 技术 
(1) 版 本 的 区 分 
目前 推出 的 PHP 5.3.1 有 多 个 版 本 ， 包 括 VC6、X86 和 VC9、X86。 
VC6: legacy Visual Studio 6 compiler， 是 使 用 此 编译 器 编译 的 。 
VC9: the Visual Studio 2008 compiler， 是 用 微软 的 VS 编辑 器 编译 的 。 
(2) 版 本 的 选择 
如 果 在 Windows 下 使 用 Apache+PHP， 选 择 VC6 版 本 ; 
如 果 在 Windows 下 使 用 IS+PHP， 选 择 VC9 版 本 。 
(3) Non Thread Safe 和 Thread Safe 
Non Thread Safe 是 非 线 程 安全 ; Thread Safe 是 线程 安全 。 官方 不 建议 将 Non Thread Safe 应 用 于 生产 环境 ， 
所 以 我 们 选择 Thread Safe 版 本 的 PHP。 


图 设计 过 程 


下 面 讲解 php-5.3.1-nts-Win32-VC9-x86 的 配置 方法 。 
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(1) 将 下 载 的 文件 php-5.3.1-nts-Win32-VC9-x86.zip 解压 ， 重 新 命名 为 phpp， 并 将 其 复制 到 指定 的 目录 下 。 
例如 C:\php、F:\php 等 。 这 里 将 php 放置 在 F:\PkhiisPHP 目录 下 。 

(2) 将 F:\PkhiisPHP\php 目录 下 的 libMySQL.dll 文件 复制 到 C:\windows\system32\ (如果 是 Windows 2000， 
则 为 CNVWINNT\system32\) 目录 下 。 

(3) 将 F:\PkhiisPHP\php 目录 下 的 php.ini-development 重 命名 为 php.ini， 如 图 1.25 所 示 ， 并 将 其 复制 到 系 
统 盘 的 windows 文件 夹 下 (例如 ， 若 C 盘 为 系统 盘 ， 则 是 C\windows) 。 
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1.25 ”生成 php.ini 
(4) 打开 php.ini 文件 并 定位 到 extension_dir ="./" 这 一 行 ， 修 改 为 extension_dir=" F:\PkhiisPHP\php\ext"。 
(5) 同样 在 php.ini 文件 中 ， 将 下 面 5 项 设置 前 的 分 号 去 掉 ， 并 设置 相应 的 参数 ， 完 成 对 CGI 和 FastCGI 
:cgi.force _ redirect= 1 
;cgifix pathinfo=1 
:fastcgi 
fastcgilogging = 0 
:cgirfe2616_headers = 1 
(6) 加 载 动态 库 。 例 如 ， 定 位 到 :extension=php MySQL.dll 这 一 行 ， 将 前 面 的 分 号 “:” 去 掉 ， 完 成 MySQL 
动态 库 的 加 载 。 
(7) PHP 安装 成 功 后 ， 还 要 对 FastCGI 进行 配置 ， 在 系统 盘 的 \system32\inetsrv\ 文 件 夹 下 找到 fegiextini 文 
件 ， 在 该 文件 的 最 后 添加 如 下 内 容 : 
[Types] 
php=PHP 
[PHP] 
ExePath=F:\PkhiisPHP\php\php-cgi.exe 
其 中 ，[Types] 指 定语 言 为 PHP; [PHP] 指 定 php-cgiexe 在 本 机 中 的 安装 位 置 。 


图 秘笈 心 法 


心 法 领悟 008: 使 用 IIS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 。 
如 果 使 用 IS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 ， 那 么 本 机 中 必须 安装 微软 的 VC++ 2008 的 运行 库 
(veredist_x64.exe 或 者 Vcredist_x86.exe) 和 FastCGI 扩 展 (fcgisetup32.msi) ， 以 确保 本 机 的 IIS 6 支持 FastCGI。 


趣味 指数 : 走 南 二 页 


图 实例 说 明 


MySQL 是 目前 最 为 流行 的 开放 源码 的 数据 库 , 是 完全 网 络 化 的 跨 平 台 的 关系 型 数据 库 系 统 。 它 是 由 MySQL 
AB 公司 开发 、 发 布 并 支持 的 。 任 何人 都 能 从 Intermet 上 下 载 MySQL 软件 ， 并 且 不 需 支付 任何 费用 。 
在 MySQL 的 官方 网 站 (http:/www.mysqlLcom) 中 可 以 下 载 到 最 新 版 本 的 MySQL 服务 器 。 
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力 关键 技术 


在 MySQL 的 官方 网 站 “(http://www.mysql.com) 中 下 载 最 新 版 本 的 MySQL 服务 器 的 具体 步骤 如 下 : 
(1) 打开 正 浏 览 器 ， 在 地 址 栏 中 输入 http://www.mysql.com， 进 入 MySQL 的 官方 网 站 ， 如 图 1.26 所 示 。 
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图 1.26 MySQL 的 官方 网 站 
(2) 单 击 Downloads 超 链接 ， 进 入 MySQL 的 Downloads 页 面 ， 如 图 1.27 所 示 。 
EY 而 561 5 WyS0l ownioais 二 Wicrosoft Intornat Rrplorer EE 和 EE 
疤 件 是 钥 辑 如 ”站 看 收 窜 册 ”工具 II) 帮助 
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图 1.27 MySQL downloads 页 面 
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(3) 单 击 MySQL 5.1 一 Generally Available( GA )release for production use 超 链接 , 进入 到 MySQL Connumity 
Server 下 载 页 面 ， 如 图 1.28 所 示 。 


i El 
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图 1.28 MySQL Connumity Server 下 载 页 面 
(4) 单 击 Download 按钮 ， 进 入 到 如 图 1.29 所 示 的 页 面 。 在 该 页 面 中 ， 可 以 选择 安装 的 平台 。 
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图 1.29 选择 安装 的 平台 
(5) 这 里 选择 Windows 平台 ， 单 击 Windows 超 链接 ， 进 入 到 如 图 1.30 所 示 的 页 面 。 在 该 页 面 中 ， 可 以 下 
载 不 同安 装 方式 的 MySQL。 
(6) 单 击 Windows Essentials(x86) 后 面 的 Download 超 链 接 ， 将 弹出 下 载 对 话 框 ， 在 该 对 话 框 中 ， 单 击 “ 保 
存 ” 按 钮 ， 下 载 Windows 安装 版 的 MySQL。 


说 明 : (1) 如 果 在 该 页 面 中 ， 没 有 出 现 Download 超 链接 ， 可 以 单 击 Pick a mirror 超 链接 ， 选 择 一 个 镜像 
进行 下 载 。 
(2) 本 书 在 讲解 MySQL 的 下 载 和 安装 时 使 用 的 是 mysql-essential-5.1.39 版 本 ， 当 您 看 到 本 书 时 ， 
这 个 版 本 可 能 不 是 最 新 的 版 本 了 。 不 过 MySQL 的 下 载 和 安装 步骤 基本 没有 变化 ， 您 仍然 可 以 使 用 
本 书 中 提供 的 步骤 、 方 法 进行 下 载 和 安装 。 
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图 1.30 MySQL 的 下 载 列 表 


图 设计 过 程 


下 面 讲解 MySQL 的 具体 安装 步骤 。 

(1) 双击 下 载 后 的 mysql-essential-5.1.39-win32.msi 文件 ， 打 开 安 装 向 导 对 话 框 ， 单 击 Next 按钮 后 ， 将 打 
开 Setup Type (选择 安装 类 型 ) 对 话 框 。 在 该 对 话 框 中 ， 共 包括 Typical (典型 ) 、Complete (完全) 和 Custom 

〈 自 定义 ) 3 种 安装 类 型 。 这 里 选择 典型 安装 ， 如 图 1.31 所 示 。 

(2) 单 击 Next 按钮 ， 将 打开 准备 安装 对 话 框 ， 在 该 对 话 框 中 将 显示 默认 的 安装 路 径 ， 单 击 Install 按钮 ， 
开始 安装 MySQL。 在 安装 的 过 程 中 ,将 显示 MySQL Enterprise 的 宣传 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 
进入 到 下 一 个 宣传 对 话 框 , 再 次 单 击 Next 按钮 , 将 打开 如 图 1.32 所 示 的 Wizard Completed (成 功 向 导 ) 对 话 框 。 
在 该 对 话 框 中 ， 采 用 默认 设置 ， 单 击 Finish 按钮 ， 继 续 安 装 MySQL 服务 器 。 
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图 1.31 选择 安装 类 型 对 话 框 图 1.32 成 功 向 导 对 话 框 


(3) 这 时 将 打开 欢迎 安装 MySQL 服务 器 的 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 将 打开 如 图 1.33 所 
示 的 MySQL 服务 器 配置 类 型 对 话 框 。 在 该 对 话 框 中 ， 可 以 选择 详细 配置 或 者 标准 配置 ， 这 里 选择 详细 配置 。 

(4) 单 击 Next 按钮 ， 将 打开 如 图 1.34 所 示 的 选择 服务 器 类 型 对 话 框 。 在 该 对 话 框 中 将 提供 开发 者 类 型 、 
服务 器 类 型 和 致力 于 MySQL 服务 类 型 。 这 里 选择 默认 的 开发 者 类 型 。 

(5) 单 击 Next 按钮 ， 将 打开 如 图 1.35 所 示 的 选择 数据 库 用 法 对 话 框 ， 在 该 对 话 框 中 提供 3 个 选项 ， 分 别 
是 多 功能 型 (Multifunctional Database)、 仅 提供 事务 型 (Transactional Database Only) 和 仅 不 提供 事务 型 
(Non-Transactional Database Only) 。 这 里 选择 多 功能 型 。 
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(6) 单 击 Next 按钮 ， 将 打开 如 图 1.36 所 示 的 设置 服务 器 安装 路 径 的 对 话 框 ， 这 里 采用 默认 设置 。 
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图 1.35 选择 数据 库 用 法 对 话 框 图 1.36 设置 服务 器 安装 路 径 对 话 框 


(7) 单 击 Next 按钮 ， 将 打开 如 图 1.37 所 示 的 设置 提示 连接 的 数量 的 对 话 框 ， 这 里 采用 默认 设置 。 
(8) 单 击 Next 按钮 ， 将 打开 如 图 1.38 所 示 的 设置 网 络 选项 对 话 框 ， 在 该 对 话 框 中 采用 默认 设置 。 
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图 1.37 设置 提示 连接 的 数量 的 对 话 框 图 1.38 设置 网 络 选项 对 话 框 


LE 技巧 : MySQL 使 用 的 默认 端口 是 3306， 在 安装 时 ， 可 以 修改 为 其 他 的 ， 例 如 3307。 但 是 一 般 情况 下 ， 不 
要 修改 默认 的 端口 号 ， 除 非 3306 端口 已 经 被 占用 。 


(9) 单 击 Next 按钮 ， 将 打开 设置 默认 的 字符 集 的 对 话 框 ， 在 该 对 话 框 中 选中 Manual Selected Default 
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Character Set/Collation 单 选 按钮 ， 并 在 Character Set (字符 集 ) 下 拉 列 表 框 中 选择 gbk (简体 中 文 ) ， 如 图 1.39 


所 示 。 


(10) 单 击 Next 按钮 ， 将 打开 如 图 1.40 所 示 的 设置 Windows 选项 的 对 话 框 ， 这 里 采用 默认 设置 。 
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1.39 ”设置 默认 的 字符 集 对 话 框 


(11) 单 击 Next 按钮 ， 将 打开 安全 设置 选项 对 话 框 ， 该 对 话 框 用 于 为 默认 用 户 root 设置 密码 ， 这 里 设置 为 


111， 如 图 1.41 所 示 。 


(12) 单 击 Next 按钮 ， 将 打开 准备 执行 对 话 框 ， 单 击 Execute 按钮 ， 完 成 服务 器 配置 ， 配 置 完 成 后 ， 将 显 


图 1.40 设置 Windows 选项 对 话 框 


示 如 图 1.42 所 示 的 对 话 框 。 单 击 Finish 按钮 ， 完 成 MySQL 的 安装 。 
Sorvor Instence Confieuralion SR f ee Contieur etion Vizerd 
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人 Modify Security Settings 
Newrootpassword ”Enpkertherodt passwerd. SR Rowe om 
TF Write confguraton fle (cipmean FiacWAySQUMYSAL Server 5 tny hg 
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Sar sarvke 
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Pe ES 
ee Press {Firish] to close the Wizard 
2 | [mr | 
图 1.41 安全 设置 选项 对 话 框 图 1.42 ”完成 服务 器 配置 


说 明 : MySQL 安装 完成 后 ， 将 在 “开始 ”/“ 所 有 程序 ”菜单 下 ， 添 加 一 个 MySQL 项 ， 在 该 项 中 包括 一 个 
MySQL Server 5.1 子 项 ， 在 该 子 项 下 ， 又 包括 MySQL Command Line Client、MySQL Server Instance 
Config Wizard 和 SunInventory Registration 3 个 子 项 。 其 中 MySQL Command Line Client 为 MySQL 
的 客户 端 命令 行 ， 通 过 该 项 ， 可 以 查看 数据 表 结 构 及 执行 SQL 语句 ; MySQL Server Instance Config 
Wizard 项 可 用 于 修改 MySQL 的 配置 ， 例 如 修改 字符 集 和 root 用 户 的 密码 等 。 
到 此 ，MySQL 安装 成 功 ， 如 果 要 查看 MySQL 的 安装 配置 信息 ， 可 以 通过 MySQL 安装 目录 下 的 my.ini 文 
件 来 完成 。 
在 my.ini 文件 中 ， 可 以 查看 到 MySQL 服务 器 的 端口 号 、MySQL 在 本 机 的 安装 位 置 、MySQL 数据 库 文件 
存储 的 位 置 ， 以 及 MySQL 数据 库 的 编码 等 配置 信息 ， 如 图 1.43 所 示 。 
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图 秘笈 心 法 


1.43 myini 文件 的 配置 信息 


心 法 领悟 009: 设置 MySQL 用 户 的 密码 。 


在 安装 MySQL 数据 库 时 ， 
库 时 必须 使 用 的 。 


图 实例 说 明 


初级 
趣味 指数 : 商 全 全 从 


- 定 要 牢记 在 第 11 步 中 设置 的 root 用 户 的 密码 ， 它 是 我 们 在 访问 MySQL 数据 


本 书 以 Windows 2003 中 使 用 的 IS 6.0 为 例 , 讲解 IS 的 安装 。 至 于 在 其 他 操作 系统 中 的 安装 步骤 是 相同 的 ， 


只 是 使 用 的 版 本 有 所 不 同 。 


图 关键 技术 


IIS 的 安装 非常 简单 ， 关 键 是 如 何 配置 IS 服务 器 。 


(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 
中 单 击 “Internet 信息 服务 (IIS) 管理 器 ”图 标 ， 将 弹出 IS 管理 器 界面 ， 如 图 1.44 所 示 。 


双击 “管理 工具 ”图 标 ， 在 弹出 的 窗口 


(2) 图 中 的 “默认 网 站 ” 即 为 IS 服务 器 的 文件 目录 。 右 键 单 击 “默认 网 站 ”， 在 弹出 的 快捷 菜单 中 选择 
“属性 ”命令 ， 设 置 网 站 的 属性 ， 如 图 1.45 所 示 。 


EEEE33 


目录 全 性 | Wri 
Bi | ee | 


| By | 。 MTshAPLlewrite 
SATT 第 法 器 主 B 录 | 文档 


99 老式 四: 


本地 
mit 算 机 ) 。 是 


习 Web 服务 扩 必 


EE3 
v0 [sc 打开 卓志 文件 格式 可 居中 


E73] 


1.44 IIS 管理 器 界面 


[CC 线 _ |] 隧 Ea1A] 者 助 


1.45 


“网 站 ”选项 卡 
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(3) 默认 选中 的 是 “网 站 ”选项 卡 ， 在 其 中 可 以 设置 TCP 端口 号 ， 这 里 将 IS 端口 号 设置 为 “82”。 设置 
完成 后 选择 “ 主 目录 ”选项 卡 ， 如 图 1.46 所 示 。 

(4) 在 “ 主 目录 ”选项 卡 中 进行 3 项 设置 : 第 1 项 是 设置 本 地 路 径 , 用 户 可 以 自行 定义 , 如 F:\PkhiisPHPWww; 
第 2 项 是 设置 执行 权限 ， 这 里 设置 为 纯 脚本 ; 第 3 项 是 添加 PHP 的 支持 。 单 击 “ 主 目录 ”选项 卡 中 的 “配置 ” 
按钮 ， 弹 出 如 图 1.47 所 示 的 “应 用 程序 配置 ”对 话 框 。 


了 可 py 
eT ee | whe lm | 
此 宽 源 的 内 容 末 目 
个 此 计算 机 上 的 语录 加) 
个 另 一 各 计 算 机 上 失 共 享 名 ) 
个 看 二 向 到 URLOD 
:0 
厂 肢 丰 资源 访问 0) 厄 记录 访问 四 
他) 厅 素 引 起 酒 巴 ) 
写 入 QE) 
厂 目录 齐 先 @] 
Cale 志 玫 应 月 程序 歇 时 执行 大 床 ) tf) 
应用 程序 名 叫 ，。 司 URORF 四 和 WD 
开 培 位 置 ; UPS> Fn 
nommw: RE | 一 
re Ew | 
Et | 上 4 
Ces ]_ ay | wh | 
图 1.46 “ 主 目录 ”选项 卡 图 1.47 应 用 程序 配置 
(5) 在 图 1.47 所 示 对 话 框 中 ， 选 择 “ 映 射 ”选项 卡 ， 完 成 添加 、 编 辑 应 用 程序 扩展 。 单 击 “ 添 加 ”按钮 ， 


在 如 图 1.48 所 示 的 对 话 框 中 ， 首先 指 定 可 执行 文件 , 这 里 指定 的 是 存储 在 系统 盘 的 system32\inetsrv\ 文 件 夹 下 的 
fcgiext.dll 文件 ， 然 后 设置 扩展 名 为 “.php”， 最 后 单 击 “ 确 定 ”按钮 ， 返 回 到 “默认 网 站 属性 ”对 话 框 。 
(6) 选择 “文档 ”选项 卡 ， 添 加 一 个 .php 的 默认 页 。 添 加 后 的 页 面 如 图 1.49 所 示 。 


[zy 
BB 录 安 4 性 。 | Im 头 。” “| 。 自 定 本 
网 | 姓 双 | SAT 名 tb 吕 | 主 上 录 文档 
到 启用 默认 内 容 文 档 他 ) 
划 本 局 及 
可 当 行 交 件 0。 [TS TE 岗 个 jm 格式 的 hs 服务 器 的 于 一 人 六 
EE ———————— ww 
他 全 部 动 作 A) 
© PB 
区 股本 引擎 GE) 
克 确认 立 件 是 天 存 全 _ | | E93 取消 EN 和 助 
图 1.48 添加 PHP 扩 展 图 1.49 添加 默认 页 


(7) 关闭 所 有 对 话 框 ， 重 启 IIS 服务 器 。 
力 设计 过 程 
(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 中 单 击 “ 添 加 /删除 程序 ”按钮 。 


(2) 单 击 左 侧 的 “添加 /删除 Windows 组 件 ” 按 钮 ， 将 会 弹出 “Windows 组 件 向 导 ” 对 话 框 。 依 次 选中 并 
双击 “Windows 组 件 向 导 ” 对 话 框 中 的 “应 用 程序 服务 器 ”选项 、“ 应 用 程序 服务 器 ”窗口 中 的 “Internet 信息 
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服务 (IIS)〉 ”选项 、“Intemet 信息 服务 HS) ”对话 框 中 的 “万 维 网 服务 ”选项 。 选 中 “万 维 网 服务 ” 复 选 框 。 
(3) 设置 完毕 后 单 击 “ 确 定 ”按钮 。 具 体操 作 过 程 如 图 1.50 所 示 。 


| 
图 选中 此 处 的 3 个 复 选 框 ， 
双击 “万 维 网 服务 ”选项 
err 42 四 信息 加 
可 用 辜 二 富 ols 3 四 ea 


于 w= | 
图 1.50 ”Intemet 信息 服务 (IIS) 

安装 完成 后 ， 即 可 使 用 IS。 

泌 笈 心 法 


心 法 领悟 010: 测试 IIS 是 否 安装 成 功 。 

安装 IIS 后 ， 即 可 在 正 浏览 器 的 地 址 栏 中 输入 http://localhost， 测 试 IS 是 否 安装 成 功 。 

如 果 本 机 的 80 端口 被 Apache 占用 ， 那 么 就 需要 修改 IS 的 端口 号 。 例 如 ， 修 改 为 82 端口 ， 那 么 测试 时 应 
该 在 地 址 栏 中 输入 http://localhost:82/。 


OE 
初级 | 
直 呆 指数 ， 夫 全 座 谷 


力 实例 说 明 


本 实例 编写 第 3 个 PHP 脚本 ， 在 IS 服务 器 下 运行 ， 测 试 通过 IIS+PHP+MySQL 搭建 的 PHP 开发 环境 是 否 
成 功 ， 运 行 结果 如 图 1.51 所 示 。 


控 作 (2) 查 痢 人 牢 QD 和 有 lolz 


多 + | 向 | 加 | 螂 忆 | 饥 国 | 旦 Pi 
TsrpEptryagr 洛 立 撕 建 HP 开 发 环境 这 | 富 


| I 
1.51 测试 独立 环境 是 否 搭建 成 功 


图 关键 技术 


确定 IS 服务 器 设置 的 本 地 路 径 ， 这 是 在 IS 的 配置 中 完成 的 ,必须 将 PHP 脚本 存储 于 IS 设置 的 本 路 径 下 
才能 够 运行 。 
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图 设计 过 程 
(1) 在 IIS 指定 的 本 地 路 径 下 〈F:\PkhiisPHP\www) ， 新 建 一 个 文本 文档 ， 在 该 文档 中 输入 如 下 内 容 : 
Pe , 
> 


(2) 将 该 文档 重 命名 为 mdex.php。 

(3) 选择 “开始 ”/“ 设 置 ”"/“ 控 制 面板 ”命令 ,在 弹出 的 窗口 中 双击 “管理 工具 ”图 标 , 然后 选择 “Internet 
信息 服务 (IS) 管理 器 ”选项 ， 依 次 展开 “本 地 计算 机 ”和 “网 站 ”节点 ， 右 键 单 击 “ 默 认 网 站 ”选项 ， 选 择 
“浏览 ”命令 ， 若 在 “Internet 信息 服务 〈IS) 管理 器 ”窗口 的 右 侧 输出 如 图 1.51 所 示 的 内 容 ， 说 明 独 立 环境 
搭建 成 功 。 


力 秘笈 心 法 


心 法 领悟 011: IIS 中 的 UrlRewrite 技术 。 

UrlRewrite 即 地 址 变换 ， 可 以 实现 静态 功能 ， 方 便 搜 索引 擎 收录 ， 比 如 http://***/news.php?id=1 可 以 变 为 
htt://***/news-1.html。 不 但 可 以 实现 开发 标记 的 隐藏， 而 且 避 免 每 个 页 面 都 输出 .php 后缀， 进而 提高 网 站 的 安 
全 性 。 

IIS 默认 是 不 支持 此 功能 的 ， 需 要 单独 安装 插件 ISAPI Rewrite3_0048_Lite.msi。 安装 完成 后 打开 IIS, 在 
WEB 属性 的 “ISAPI 筛选 器 ”里 添加 位 于 安装 目录 的 Helicon\ISAPI Rewrite3 文件 夹 里 的 ISAPI Rewrite.dll 即 
可 ， 名 称 可 以 自 定义 。 


1.4 LAMP 一 一 独立 配置 PHP 开发 环境 


在 Linux 下 搭建 PHP 环境 比 在 Windows 中 要 复杂 一 些 ， 除 了 Apache、PHP 等 软件 外 ， 还 要 安装 一 些 相关 
工具 ， 并 设置 必要 参数 。 这 里 给 出 在 Linux 下 搭建 PHP 环境 的 必要 步骤 ， 如 果 用 户 在 安装 过 程 中 遇 到 特殊 的 问 
题 ， 还 需要 翻阅 与 Linux 相关 的 资料 、 书 籍 或 者 手册 。 

安装 之 前 要 准备 的 安装 包 如 下 : 

apache_ 1.3.41.tar.gz 

php-5.0.0.tar.gz 

mysql-standard-5.0.0-alpha-pc-linux-1686.tar.gz 

libxml2-2.6.19.tar.gz 


说 明 : 本 书 中 在 讲解 Linux 下 搭建 PHP 开发 环境 时 ， 使 用 的 软件 版 本 相对 较 低 ， 如 果 读 者 想 要 下 载 这 些 软 
件 ， 可 以 登录 http://221.8.65.77/mrbook/bookzy/linux.rar。 


这 里 首先 在 Linux 系统 的 /asrlocal/ 文 件 夹 下 新 建 一 个 work 文 件 夹 ,并 将 使 用 的 软件 全 部 存储 在 此 文件 夹 下 。 


中 级 
趣味 指数 : 合 伍 全 从 


图 实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 Apache 服务 器 。Apache 服务 器 安装 成 功 后 测试 的 运行 结果 如 图 1.52 
所 示 。 
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a 
| 文件 EE 炉 贺 EE) 查 旭 WD 转 到 G) 书签 BB 工具 WD 商品 WD 帮助 四 


| 各- 襄 - 暑 [meatev ee] 和 ~ 


| 熏 主 页 哇 书 签 帮 Rei Hat Network 曾 Suppon 殴 Shop 曾 Products 的 Trining 


Apache 的 文件 已 经 包含 在 该 版 本 中 。 
你 可 以 在 使 用 Apache 的 网 站 伺服 器 上 ， 自由 的 使 用 下 面 之 图 示 ， 感谢 您 
使 用 Apache ! 


二 一 一 


Ts A 攻 - 


| EE RA 完成 _ -| 


图 1.52 Apache 配置 成 功 


EE 


图 关键 技术 


Linux 系统 下 配置 Apache 服务 器 使 用 的 仍 是 httpd.conf 文件 ， 该 文件 位 于 /usr/local/apache/conf 中 。 
(1) 在 httpd.conf 文 件 中 ， 定 位 到 如 图 1.53 所 示 的 位 置 ， 添 加 相应 的 内 容 ， 并 设置 PHP 文件 的 后 级 。 
(2) 同样 在 httpd.conf 文 件 中 ， 定 位 到 如 图 1.54 所 示 的 位 置 ， 设 置 PHP 文件 的 默认 页 。 


| l= Di% | = 加 I% 
| 文 伯 E)。 护 辑 人 @ 查看 WD 搜索 5) 工具 了 文档 D) 帮助 
攻 久 .加 | 电 9e 村 和 白 区 ， 芒 岛 .加 | 双 9e 区 怠 白 区 ， 
新 建 打开 保存 打印 撤消 下 剪 切 复制 帖 贴 ”查找 新 建 打开 保存 打印 撤消 下 蓝 前 切 复 吊 帖 贴 查找 
站 mapdeonty x hapdeont x 

生 目标 定位 “> 只 
AddType application/x-compress 也 lasee| lModule mod_dir.c> Et 
AddType application/x-gzip gz .gz Directorylndex index.html [index.php] 
ARqJTYpe appTication7x=httpFphp -ppp ANNE .php4_ hd 
和 | [wn] 二 
行 774, 列 43 插入 行 364， 列 40 插入 
1.53 ”设置 文件 后 级 图 1.54 设置 默认 文件 


图 设计 过 程 
安装 Apache 服 务 器 , 首先 需要 打开 Linux 终 端 (Linux 下 几乎 所 有 的 软件 都 需要 在 终端 下 安装 )。 选 择 RedHat9 
的 “ 主 菜单 ”/“ 系 统 工具 ”命令 ， 在 弹出 的 子 菜单 中 选择 “终端 ” 命令 。Apache 服务 器 的 安装 步骤 如 下 : 
(1) 解压 apache_1.3.41.tar.gz 压缩 包 ， 将 其 存储 到 url/local/apache 目录 下 ， 执 行 的 命令 如 图 1.55 所 示 。 
DA spoolbost/ sol ranch 1 341 -二 x 
| 文件 ED。 编 鸭 E) 查看 V)。 终 编 D。 转 到 G) 帮助 ED a 


|[root@loca lhost root]# [edusr7Toca 7wori] © 
|[root@localhost work]# [lar xfz apache .5.41.137 :gO 


r a lhost work]# Ephe TH 
Im ca Ihost apache_1.3.41]# /configare —prefix=/usr/ 
|loca l/apache --enable-nodule=so 


(nT iar Ing for_ Apche, Wrsion 1°3.41 
+ using installation path layout: Mpache (eonfig. layout) 

[creating Mhkefile 

[cresting Configuration.apaei in are 

(Greating ee in ereDsspport 

[eesting Mierile in sre/regex 

[reating Mierile in are/os/unix 

[Gestine Merile in sre/ap 


图 1.55 输入 命令 


ME 请 令 导 污 
@ 进入 Apache 安装 文件 的 目录 。 
@ 解压 Apache 服务 器 的 安装 包 。 
@ 进入 apache 1.3.41 目录 。 
@ 将 Apache 服务 器 安装 到 usr/local/apache 目录 下 。 
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(2) 执行 make 命令 ， 编 译 apache 文件 。 执 行 命令 如 图 1.56 所 示 。 
(3) 执行 make install 命令 ， 开 始 安装 Apache 服务 器 。 执 行 命令 如 图 1.57 所 示 。 


文 作 B。 编辑 (E) 。 查看 () 四 转 到 @) 帮助 由 
+ checking for system header files 

+ adding selected nodules 

+ using system Expat 

+ using -1d1 for vendor DSO support 

+ checking sizeof various data types 

+ doing sanity check on conpiler and options 
(Creating Mkefile in sre/support 

Creating Mkefile in sreyregex 

Greating Mkefile in sre/os/unix 


(Greating Mkefile in sre/ap 一 一 -一 一 — 

(Creating Mkefile in sre/min 文件 四 ”编辑 (E) ”查看 (VW) 终端 中 。 转 到 (G) 帮助 纯 

[Creating Mkefile in sre/nodules/standard mke[1]: Leaving directory /usr/local/work/apache 1.3.41 

-= e [Eroot@loca lhost apache 1 3 41]# mke install | 
mmke[1]: Entering directory /usr/local/work/apache 1.3.41 mke[1]; Entering directory /usr/local/work/apache _1.3.41 
tr diroetory /ost/ oonl/ uli/apade -41are' ===> [nktree: Creating Apache installation tree] 

E sre/regex sre/he lpers/mhdir .sh /usr/ local/apache/bin 


图 1.56 执行 make 命令 编译 文件 图 1.57 执行 make install 安装 命令 
(4) Apache 服务 器 安装 成 功 后 ， 将 给 出 如 图 1.58 所 示 的 命令 提示 。 


“~ pr Try 
| 文人 (BD 坊 负 EE。 查看 (WW 疼 注 DD 转 到 @) 帮助 册 
Imke[1]: Leavi 


ory /usr/local/wrk/apache_1 


| You now have suceessfully built and installed the 1 
| Apache 1.3 HITP server. To verify that Apache actually | 
| works correctly you now should first check the 1 
| Cinitially ereated or preserved) configuration files | 

1 


/usr/ local/apache/conf/ht tpd. conf 

| 

| and then you should be able to inmediately fire up 
| Apache the first tine by running: 


| 
| usr/local/apache/bin/apachect! start 
| 
| 


Thanks for using Apache . The Apache Group 


1 http://www,apacl 


图 1.58 ”安装 成 功 返 回 命令 


图 秘笈 心 法 
心 法 领悟 012: Linux 下 启动 Apache。 
安装 成 功 后 ， 就 可 以 启动 Apache 服务 器 了 ， 启 动 Apache 服务 器 使 用 的 命令 如 图 1.59 所 示 。 


“~ rT Ty x 
文人 BD 编辑 E) 查看 (WD 终端 D。 转 到 G》 帮助 H 

[root@loca lhost apache_1.3.41]# /usr/local/apache/bin/apachect! start 
/usr/loca /apache/bin/apachect! start: httpd started 

| EE apache_1.3.41]# 国 


1.59 执行 启动 Apache 服务 器 的 命令 


趣味 指数 : 价 售 信众 


图 实例 说 明 
本 实例 讲解 在 Linux 下 安装 MySQL 数据 库 , 使 用 的 版 本 是 mysql-standard-5.0.0- alpha- pc- linux-i686 .tar.gz。 
图 关键 技术 
(1) 在 Linux 操作 系统 中 ， 备 份 和 还 原 MySQL 使 用 的 命令 如 下 : 
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备份 : 
mysqldump -uroot -proot -RR 数据 库 名 称 >C:/data.sql 
还 原 : 
mysql -uroot -proot -D 数据 库 名 称 < C:/data.sql 
(2) 在 Linux 操作 系统 中 ， 设 置 和 修改 root 用 户 密码 的 命令 如 下 : 
设置 密码 : 
mysqladmin —uroot password root 
修改 密码 : 
mysqladmin -uroot -p 旧 密码 password 新 密码 
图 设计 过 程 
下 面 讲解 其 具体 的 安装 步骤 。 
(1) 安装 MySQL 数据 库 同样 要 在 Linux 终端 的 命令 中 进行 。 首 先 创 建 MySQL 账号 ， 并 将 新 建 账号 加 入 
到 组 群 ， 有 具体 使 用 的 操作 命令 如 图 1.60 所 示 。 


To start msqld at b 
to the right place f' 


0 copy support-files/nysql.server 


DO SET A PASSWRD FOR THE MSGL USER 1 


can start the MSQL dae 
cd /hin/nysqld_safe & 


[iow ean test the MSOL daenon with the benchmrks in the ‘sql-bench’ directory: 加 


图 1.60 MySQL 的 安装 命令 


于 代 码 导 污 
@ 创建 MySQL 账号 。 
@ 加 入 组 群 。 
@ 进入 MySQL 安装 文件 的 目录 。 
@ 解压 MySQL 服务 器 软件 。 
目 以 链接 的 方式 建立 /usr/local/mysql 目录 。 
@ 进入 MySQL 目录 。 
@ 在 /ust/local/mysql/data 中 建立 MySQL 数据 库 。 


(2) 在 完成 数据 库 的 安装 之 后 ， 修 改 文件 的 权限 。 具 体操 作 命令 如 图 1.61 所 示 。 


Suppor t MSQL by buying support/licenses at htips://order .mysql.com 
[root@loca lhost nysql]# [chow -R root . | 


[root@loca Ihost mysql]# |chow -R nysql data 
root@loca lhost nysql]#|chgrp -R mysql . 


i 


图 1.61 修改 文件 权限 的 命令 
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(3) 完成 权限 修改 后 ， 看 一 下 启动 MySQL 服务 器 的 命令 。 具 体 命令 如 图 1.62 所 示 。 


~ Er ~ x 
EC 


Jiroot@loca lhost nysql]#[/usr7ioca /nysql /Din/ny qd sufe user-nysql & 
| 7621 
| Exit 127 /usr/ local/mysql/bin/mysql_safe -user=nysql 


[reo host mysql]# Starting nysqld daenon with databases from /usr/local/ 
Jsql/data 


| Ls 


host nysql]s 目 


图 1.62 启动 MySQL 的 命令 


图 秘笈 心 法 
心 法 领悟 013: Linux 下 修改 MySQL 数据 库 用 户 的 密码 。 
可 以 通过 命令 修改 MySQL 数据 库 用 户 的 密码 .在 如 图 1.63 所 示 的 命令 中 , 首先 以 无 密码 的 方式 登录 MySQL 
数据 库 ， 然 后 通过 命令 设置 MySQL 数据 库 用 户 的 密码 ， 最 后 通过 新 设置 的 密码 重新 登录 MySQL 数据 库 。 
文人 PE) 坊 辑 EE) 查看 V) 余 萄 站 转 于 G) 机 助 HD 
i 


nysql> exits 
Bye 


[root@loca lhost nysql]# 
[root@loca Ihost nysq1]# [7T 


ot password rool 
TD 


Your MSQL connection id i 


Type ‘help:' or “\h” for help. Type ‘\e’ to clear the buffer, 


| -已 hn 


图 1.63 登录 MySQL 和 设置 MySQL 登录 密码 


OO Wo 


趣味 指数 : 依依 请 闪 | 


力 实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 PHP 5.0。 安装 之 前 , 首先 需要 查看 libxml 的 版 本 号 , 如 果 小 于 2.5.10， 
则 需要 先 安装 libxml 的 高 版 本 ， 否 则 ， 可 以 直接 安装 PHP 5.0。 


力 关键 技术 


这 里 以 libxml2-2.6.19.tar.gz 为 例 ， 讲 解 libxml 的 安装 步骤 。 
(1) 将 libxml2-2.6.19.tar.gz 进行 解压 ， 并 将 其 安装 到 指定 的 文件 夹 下 ， 其 操作 命令 如 图 1.64 所 示 。 


~ re rr x 
Em 
[2 


图 1.64 解压 libxml 
ES 代码 导读 


@ 进入 usrlocal/work 文件 夹 ( libxml2-2.6.19 压缩 包 存 储 的 位 置 ) 。 
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@ 解压 libxml2-2.6.19.tar.gz。 
@@ 进入 libxml2-2.6.19 文件 夹 。 

@ 将 libxml2-2.6.19 安装 到 /usr/local/llibxml2. 

(2) 完成 libxml 的 解压 后 ， 开 始 编译 文件 ， 使 用 的 命令 如 图 1.65 所 示 
(3) 文件 编译 完成 后 ， 就 可 以 执行 安装 操作 了 ， 使 用 的 命令 如 图 1.66 所 示 。 


终 洋 中 转 到 G) 帮助 册 
/local/work/ libxml2-2.6.19/python/ test 
/iibxml 9/py thon 


Er 


root@loca lhos 


图 1.66 执行 安装 


图 1.65 编译 文件 


图 设计 过 程 


本 书 使 用 的 版 本 是 php-5.0.0.tar.gz。 下 面 来 看 具体 的 安装 步骤 。 
(1) 将 php-5.0.0.tar.gz 解压 到 指定 的 文件 夹 下 ， 通 过 命令 进行 配置 ， 使 用 的 操作 命令 如 图 1.67 所 示 


站 


有 查看 (V) 二 转 到 GG) 


文 作 加 


with-apxs™/usr/local/apache /bin/apxs \| 
dir=/usr/ local/ libxm2 一 enable-sock| 


图 1.67 安装 PHP 


ES 代码 导读 
@ 进入 usr/local/work 文件 夹 (php-5.0.0.tar.gz 压缩 包 存 储 的 位 置 ) 。 


@ 解压 php-5.0.0.tar.gz。 
@@ 配置 文件 。 

0 完成 解压 和 配置 操作 后 ， 对 文件 进行 编译 ， 使 用 的 命令 如 下 : 

3) Li 站 成 后 ， 执 行 安装 操作 ， 使 用 的 命令 如 下 : 

(4) ) 最后 ， 在 命令 中 将 出 现 如 图 1.68 所 示 的 内 容 ， 说 明 PHP 安装 成 功 。 


文件 E) ”编辑 [E) ”查看 (V) 终端 D 。 转 到 G 帮助 (H 


图 1.68 PHP 安装 成 功 


图 秘笈 心 法 


心 法 领悟 014: 在 Linux 下 创建 php.ini。 
在 Linux 操作 系统 中 ，PHP 的 配置 文件 仍然 是 php.ini， 其 创建 方法 如 下 
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在 PHP 文件 夹 下 找到 php.ini-dist 或 者 php ini-recommended， 将 其 复制 到 /usrlocallib 目录 下 ， 并 重 命 名 为 


php.ini。 
cp php.ini-dist /usr/local/lib/php.ini 
= , 
| 
实例 015 | 


图 实例 说 明 


在 Linux 系统 下 搭建 完成 PHP 开发 环境 后 ， 编 写 一 个 小 实例 ， 测 试 一 下 环境 是 否 搭建 成 功 。 在 Mozilla 浏 
览 器 的 地 址 栏 中 输入 http:Wlocalhosttestphp， 运 行 结 果 如 图 1.69 所 示 。 


文人 BD 区 所， 查看 转 1QD Whip 


村 总 名 = 隆 : 镜 [hop /oralboe es php 


全 主页 | 嘻 书 签 丰 Red Hat Newark 莉 Sppan 的 Shop 首 mahuas 的 Taining 


图 1.69 测试 运行 结果 


图 关键 技术 
在 Linux 操作 系统 下 ， 通 过 gedit 工具 编写 PHP 脚本 。 
图 设计 过 程 


通过 gedit 工具 编写 一 个 PHP 脚本 testphp， 并 存储 于 Apache 的 htdocs 文件 夹 下 。test.php 的 代码 如 图 1.70 
所 示 。 


文 作 (E) 。 护 辑 (E) 查看 (V 搜索 S) 工具 WD 文档 D) 帮助 (H) 


ESHGe 人 DOE, 


新 建 打开 保存 打印 撤消 重复 ” 章 急 复制 粘贴 ”查找 


Destphp x 
php 

Phpinfo0: 
?> 


图 1.70 testphp 文件 的 内 容 
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图 秘笈 心 法 


心 法 领悟 015: Linux 下 安装 XAMPP 集成 环境 。 
本 实例 介绍 的 是 在 Linux 操作 系统 下 独立 搭建 PHP 的 开发 环境 ,读者 也 可 以 使 用 XAMPP 的 
xampp-linux-1.7.3a.tar.gz 版 本 直接 在 Linux 操作 系统 下 搭建 集成 的 开发 环境 。 


Linux 版 PHP 集成 化 安装 包 


1.5 XAMPP 


前 面 已 经 介绍 过 如 何在 Windows 操作 系统 下 应 用 XAMPP 集成 化 安装 包 配 置 PHP 的 开发 环境 ， 这 里 将 介 
绍 如 何在 Linux 操作 系统 下 通过 XAMPP 配置 PHP 的 开发 环境 以 及 其 基本 应 用 。 


| 
| 


“PHP 开发 环境 的 集成 化 中 级 
趣味 指数 : 寅 食 食 侧 


实例 016 


图 实例 说 明 


在 Linux 操作 系统 下 ， 也 可 以 使 用 集成 的 软件 来 配置 PHP 开发 环境 ， 它 就 是 XAMPP 的 Linux 版 。 配 置 成 
功 后 ， 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/index.php， 运 行 结果 如 图 1.71 所 示 。 


Vv 国电 3 
文件 (E) 编辑 玉 ) 查 硬 VW) 转 到 G) 书签 B) 工具 D 诊 D(W 帮助 四 
访 - 襄 、 BExal 
番 主 页 | 奸 书 签 才 Red Hat Network 茵 Support 茵 Shop 项 poaucs 莉 Tommg 
XAMPP for Linux 
5 
欢迎 使 用 XAMPP for Linux 1.53n 1 
祝贺 您 : 
您 已 经 成 功 安装 了 XAMPP! 


现存 区 可 以 开 嫩 使 用 Apache 以 及 其 他 的 组 作 ， 首 先 ， 您 可 以 适 过 左 便 的 导航 杂 上 的 状态 功 琵 来 查看 他 们 是 否 工作 正 芝 


您 可 以 二 过 阐 鉴 mps 012001 成 帮 bmpe//iocaibog 来 验 放 Opensst 
机 人 好 运 , Kai ‘Oswald Seidler + Kay Vogeigeang 


FhpSOLieAémnin 
Wehalpwr 


EF- ED 1 Fe 
图 1.71 Linux 版 的 XAMPP 


图 关键 技术 


在 Linux 操作 系统 下 安装 XAMPP， 必 须 在 Linux “ 主 菜单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 通过 指令 
来 完成 ， 切 记 不 要 使 用 任何 微软 操作 系统 下 的 工具 来 进行 操作 。 


设计 过 程 
Linux 下 安装 XAMPP 的 步骤 如 下 : 
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(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ”命令 。 

(2) 在 命令 模式 下 ， 首 先进 入 系统 的 根 目 录 。 

(3) 通过 mkdir 命令 在 根 目录 下 创建 一 个 opt 目录 。 

(4) 通过 tar xvfz 命令 将 xampp 解压 缩 到 opt 目录 下 。 

(5) 按 Enter 键 ， 执 行 XAMPP 的 解压 缩 ， 直 到 安装 成 功 ， 其 具体 使 用 的 命令 如 图 1.72 所 示 。 
(6) 安装 成 功 后 ， 查 看 /opt/lampp 目录 ， 如 图 1.73 所 示 。 


文件 四 编辑 [E) ”查看 WD 转 到 (@) 书签) 帮助 由 


.bb. A 电动 | 名 
后 退 时 向 上 一 级 刷新 主 文件 夹 


oo 
alhost /J nkdir opt 
alhost /J# tar xvfz xanpp-linux-1.5.3a.tar-gz -C /op 


图 1.72 XAMPP 的 安装 图 1.73 查看 安装 的 内 容 


图 秘笈 心 法 

心 法 领悟 016: Linux 下 安装 XAMPP 的 注意 事项 。 

在 Linux 操作 系统 下 执行 XAMPP 的 解压 缩 时 ， 必 须 进入 到 系统 的 根 目录 下 ， 并 且 要 在 根 目录 下 创建 一 个 
子 目 录 ， 然 后 才 可 以 执行 解压 缩 的 命令 。 和 否则 ， 将 提示 找 不 到 指定 的 目录 或 者 文件 。 


Ee 
Ml 


a deh 


力 实例 说 明 


在 实例 017 中 , 已 经 介绍 了 如 何在 Linux 操作 系统 下 安装 XAMPP， 本 实例 我 们 将 介绍 在 Linux 操作 系统 下 
如 何 启动 XAMPP， 其 使 用 的 命令 如 图 1.74 所 示 。 


文件 E) 编 刍 EE》 查看 (和 余 痪 一 苇 到 G) 帮助 四 
ont ape/ Merpp lst 
Starting XAMPP for Linux 1.5.3 
NPP: Siarting Apache with SSL C2nd PHP5) 


NAMPP: Starting MSOL.. 
NWFP: Starting PopTPD “ 
XANPP for Li 

[rootetoca Ihost 7 


1.74 启动 XAMPP 


转 关键 技术 
在 Linux 操作 系统 下 启动 XAMPP， 同 样 要 进入 到 Linux “ 主 菜单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 ， 


所 使 用 的 命令 如 下 : 
/optlamp/lamp start 


图 设计 过 程 


Linux 下 启动 XAMPP 的 步骤 如 下 : 
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(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ”命令 。 
(2) 直接 输入 命令 /opt/lamp/lamp start。 
(3) 按 Enter 键 ， 执 行 XAMPP 的 启动 操作 。 命 令 运行 结果 如 图 1.75 所 示 。 


文件 E) ”编辑 EE) ”查看 (WW 。 终端 下。 甘于 G) 有 有 动 -四 


[reo eos hom :TT 
TREE 


XANPP: Starting Apache 
MU 


图 1.75 XAMPP 启动 成 功 
也 笈 心 法 
心 法 领悟 017: 停止 XAMPP 的 命令 。 


Linux 下 停止 XAMPP 的 命令 如 下 : 
/lopt/lamp/lamp stop 


实例 说 明 


在 XAMPP 中 ， 默 认 情 况 下 通过 phpMyAdmin 以 root 用 户 的 身份 登录 MySQL 数据 库 是 不 需要 密码 的 ， 


为 了 确保 数据 库 的 安全 ， 应 该 给 root 用 户 设 置 一 个 密码 。 这 就 是 本 实例 要 介绍 的 内 容 


密码 。 
力 关键 技术 


在 Linux 操作 系统 下 为 MySQL 数据 库 的 root 用 户 设置 密码 使 用 的 命令 如 下 : 
/opt/lamp/bin/mysqladmin —u root password “newpassword™ 


图 设计 过 程 


Linux 下 设置 MySQL 数据 库 root 用 户 密码 的 步骤 如 下 : 
(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/ “终端 ” 命 令 。 


如 何 为 root 用 户 设置 


(2) 直接 输入 命令 /opt/lamp/bin/mysqladmin -u root password "111"， 这 里 设置 root 用 户 的 密码 为 “111”。 


(3) 按 Enter 键 ， 执 行 该 命令 ， 其 运行 结果 如 图 1.76 所 示 。 


1.76 设置 root 用户 的 密码 


力 秘笈 心 法 


心 法 领悟 018: 印 载 XAMPP 命令 。 
Linux 下 印 载 XAMPP 的 命令 如 下 : 
mf /opt/lampp 
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力 实例 说 明 

Linux 系统 下 PHP 的 集成 开发 环境 XAMPP 已 经 配置 成 功 ， 下 面 编写 一 个 小 实例 ， 应 用 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 通 过 这 个 实例 熟悉 一 下 在 Linux 下 XAMPP 的 运用 。 在 Mozilla 浏览 器 的 地 址 栏 中 输入 
http://127.0.0.1/text/index.php， 运 行 结果 如 图 1.77 所 示 。 


ee phpinfo 


Morilla, [Build ID: 20030225} 
文件 编 得 (E) 查看 (V) 转 到 G) 书签 B) 工具 D 窗口 W) 帮助 (H) 


~ 愤 | 要 
> 点 ， 电 、 得 各 mm//127.0.0.lesv [PRT 


稚 主 页 | 奸 书 签 参 Red Hat Netwatk 萝 Suppon 项 Shop 曾 Poducs 的 Training 


图 1.77 输出 PHP 的 配置 信息 


力 关键 技术 


在 Linux 操作 系统 下 运用 XAMPP 开发 PHP 程序 ， 首 先 要 确立 XAMPP 的 程序 运行 文件 夹 ， 即 明确 创建 的 
程序 要 存储 在 哪个 文件 夹 中 才 可 以 运行 。XAMPP 中 的 重要 档案 和 目录 如 下 : 
/opt/lampp/bin/: XAMPP 指令 的 根 目录 。 例 如 /opt/lampp/bin/mysql 用 来 执行 MySQL 。 
/opt/lampp/htdocs/: Apache 文件 根 目录 。 
/opt/lampp/etc/httpd.conf: Apache 设 定 档案 。 
/opt/lampp/etc/my.cnf: MySQL 设 定 档 案 。 
/opt/lampp/etc/php.ini: PHP 设 定 档案 。 
/opt/lampp/phpmyadmin/config.inc.php: phpMyAdmin 设 定 档 案 。 


图 设计 过 程 
在 XAMPP 中 开发 PHP 程序 的 操作 步骤 如 下 : 


(1) 首先 通过 gedit 工具 编写 一 个 PHP 脚本 ， 应 用 phpinfo0 函 数 输出 PHP 的 配置 信息 ， 如 图 1.78 所 示 。 
(2) 单 击 图 1.78 中 的 “文件 ”按钮 ， 选 择 “ 另 存 为 ”命令 ， 将 该 文件 存储 于 XAMPP 的 htdocs/ 目 录 下 ， 


加 加固 回回 加 


第 1 章 开发 环境 
并 且 命 名 为 index.php， 如 图 1.79 所 示 。 


新 建文 伯 类 (| 到 际 文 HfL | 重生 名 文 作 R 


/opvlampp/ hidocs 

区 fine 
index homl 

J index.php™ 


文 作坊 辑 全 看 WJ 神曲。 其 D 7 


号 馈 . 唱 | 昌 9e 区 下 自 区 ， 


webalizer/ 
ampp/ 


新 建 打开 保存 打印 撤消 牺 切 复制 粘贴 ”查找 
口 来 命名 1e x 
<? phi hs): 1 wm 
es popaniood Eee Re 
其 取 注 (07 六 网 定 (0 
图 1.78 编辑 PHP 脚本 文件 图 1.79 完成 PHP 文件 的 存储 
(3) 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http:/127.0.0.l/textindex.php， 运 行 结果 如 图 1.77 所 示 (参看 “ 实 


例 说 明 ”) 。 

秘笈 心 法 

心 法 领悟 019: Linux 下 如 何 修改 MySQL 缺 省 字符 集 。 
在 Linux 下 修改 MySQL 缺 省 字符 集 为 utfg， 操 作 的 文件 是 my.cnf， 操 作 的 内 容 如 下 : 
[client] 

default_character_set=utf8 

[mysqld] 

# default-character-set=utf8 

character-set-server = utf8 

collation-server = utf8_general ci 

[mysql] 

default_character_set=utf8 


1.6 Dreamweaver 开发 工具 


Dreamweaver 是 Macromedia 公司 开发 的 Web 站 点 和 应 用 程序 的 专业 开发 工具 。 它 将 可 视 布局 工具 、 应 用 
程序 开发 功能 和 代码 编辑 组 合 在 一 起 。 


中 级 | 
趣味 指数 : 二 生生 个 


图 实例 说 明 

应 用 Dreamweaver 开发 网 站 ， 首 先 必须 考虑 网 页 的 编码 格式 的 选择 。 因 为 如 果 网 页 的 编码 格式 有 局 限 性 ， 
那么 将 导致 网 站 在 一 些 特定 的 情况 下 运行 时 出 现 乱码 ， 将 不 利于 网 站 程序 的 后 期 更 新 和 维护 。 例 如 ， 如 果 网 站 
在 编写 时 使 用 的 是 gb2312 编码 ， 当 程序 在 繁体 操作 系统 中 运行 时 就 会 出 现 乱 码 ， 结 果 如 图 1.80 所 示 。 
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重 016[I] - 寻 李 本 [ 梧 四 oi60] - 记 地 本 -alx 
档案 人 ”篇 加 加、 裕 式 们 ) 被 枫 臣 说明 G) EEC TIEETTETIETTI 
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图 1.80 繁体 操作 系统 下 查看 gb2312 编码 格式 文件 与 源 文件 对 比 


图 关键 技术 

对 于 网 站 的 开发 ， 编 码 格式 的 选择 很 重要 。 如 果 使 用 Dreamweaver 开发 网 站 ， 那 么 可 以 在 Dreamweaver 编 
辑 菜单 的 “首选 参数 ”/“ 新 建文 档 ”/“ 默 认 编 码 ” 中 设置 新 建文 件 的 编码 格式 。 这 样 就 不 必 再 为 创建 的 每 个 文 
件 的 编码 而 担心 ， 因 为 它们 的 编码 格式 是 统一 的 。 
图 设计 过 程 

统一 Dreamweaver 创建 文件 编码 格式 的 方法 如 下 : 

(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 编 辑 ” 菜 单 命令 ， 单 击 “ 首 选 参数 ”选项 ， 将 弹出 如 图 1.81 所 
示 的 页 面 。 


Bs 
新 建文 档 
Mx 区 re -| 
默认 扩展 各 玫 ): | he 


Mi rs): [rv 1.0 1: a = 


Mumia) TEN 
克 当 打开 米 指定 炉 码 的 现 有 文 冲 时 使 用 


DD | 
[TT 
友 控 contrelW 拓 人 入 时 时 示 “ 半 当 妆 档 ”对话 笃 Q) 


[mm i | 
图 1.81 设置 文件 的 编码 格式 
(2) 在 图 1.81 所 示 页 面 中 ， 指 定 默认 编码 ， 终 后 单 击 “ 确 定 ” 按 钮 。 


力 秘笈 心 法 


心 法 领悟 020: 在 Dreamweaver 中 设置 编码 。 

在 Dreamweaver 的 “首选 参数 ”设置 中 ， 不 但 可 以 设置 默认 编码 的 格式 ， 还 可 以 进行 其 他 的 一 些 设置 ， 例 
如 css 样式、 站 点 和 字体 等 。 

对 于 文件 编码 格式 的 选择 ， 强 烈 建议 读者 使 用 utf-8， 因 为 这 样 可 以 与 国际 接轨 ， 如 果 单 纯 地 使 用 gb2312 
编码 ， 那 么 一 旦 程序 要 更 改编 码 格式 ， 网 页 将 出 现 乱 码 。 如 果 使 用 utf-8 编码 格式 ， 就 不 会 出 现任 何 问题 ， 因 为 
这 个 编码 格式 是 通用 的 。 


力 实例 说 明 


讲解 了 在 Dreamweaver 中 如 何 设置 编码 格式 之 后 ， 下 面 介绍 一 下 它 的 具体 应 在 Dreamweaver 中 创建 
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表格 。 运 行 结果 如 图 1.82 所 示 。 


文件 篇 抽 到 和 由 下 加 I 具 Q i”| 讲 
于 古 加 | 导 http //127 oo ar/01/021 本 | 固 转 到 | 护 后 ” 


请 户 一 | 
| 习 
BE [i Oa 网 


图 1.82 在 Dreamweaver 中 创建 表格 


力 关键 技术 


在 Dreamweaver 中 创建 表格 ， 有 两 种 方法 : 

第 一 种 ， 选 择 菜单 中 的 “插入 ”命令 ， 在 弹出 的 列表 中 选择 “表格 ”命令 ， 在 弹出 的 “表格 ”对 话 框 中 完 
成 表格 的 创建 操作 ; 

第 二 种 ， 直 接 在 “常用 ”工具 栏 中 单 击 “ 表 格 ” 国 按钮 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 操作 。 
图 设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 如 下 : 


(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 文 件 ”/“ 新 建 ” 命 令 ， 在 弹出 的 “新 建文 档 ” 对 话 框 中 创建 一 
个 “动态 页 ”/“PHP” 文 件 ， 最 后 单 击 “创建 ”按钮 ， 完 成 动态 PHP 文件 的 创建 ， 如 图 1.83 所 示 。 


图 1.83 创建 PHP 动态 文件 


(2) 如 图 1.84 所 示 ， 在 创建 的 Untitled-1 文件 中 ， 首 先 切 换 到 设计 模式 下 ， 然 后 在 工具 栏 中 选择 “常用 ” 
选项 ， 单 击 “ 表 格 ” 国 按钮 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 。 


EDC 


1.84 在 设计 模式 下 添加 表格 
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(3) 表格 创建 对 话 框 如 图 1.85 所 示 ， 在 其 中 可 以 设置 表格 的 行 数 、 列 数 、 表 格 宽度 、 边 框 粗细 、 单 元 格 
边 距 和 单元 格 间距 等 。 设 置 完 成 后 单 击 “ 确 定 ” 按 钮 ， 完 成 表格 的 创建 。 


图 1.85 表格 的 创建 
(4) 表格 创建 完成 后 ， 将 在 设计 界面 中 输出 如 图 1.86 所 示 的 内 容 。 
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图 1.86 创建 完成 的 表格 
(5) 表 格 创建 完成 , 选择 “文件 ”保存 "命令 ,将 其 存储 于 apache 服务 器 指定 的 文件 夹 下 , 命名 为 index.php。 
运行 结果 请 参考 实例 说 明 。 
图 秘笈 心 法 
心 法 领悟 021: 操作 表格 的 小 技巧 。 
在 图 1.86 所 示 的 表格 设计 界面 中 ， 表 格 处 于 选中 状态 时 ， 可 以 设置 其 属性 ， 包 括 行 数 、 列 数 、 表 格 宽度 、 
边框 粗细 、 单 元 格 边 距 、 单 元 格 间距 、 背 景 颜 色 、 边 框 颜色 和 背景 图 像 等 。 


实例 022 


力 实例 说 明 


实例 021 讲解 如 何在 Dreamweaver 中 创建 表格 ， 本 实例 将 讲解 如 何 向 表格 中 插入 图 片 。 本 实例 的 运行 结果 
如 图 1.87 所 示 。 


图 1.87 表格 中 插入 宠物 图 片 


图 关键 技术 


在 Dreamweaver 中 ， 向 创建 的 表格 中 插入 图 片 时 ， 必 须 注 意图 片 的 存储 位 置 ， 最 好 的 方式 就 是 先 将 图 片 存 
储 到 实例 的 根 目录 下 ， 这 样 当 实例 在 运行 过 程 中 ， 不 会 因为 机 器 的 更 换 而 找 不 到 图 片 。 

如 果 没 有 将 图 片 存储 到 实例 的 根 目录 下 ， 在 执行 图 片 的 插入 操作 过 程 中 ， 将 给 出 一 个 如 图 1.88 所 示 的 提示 
信息 ， 提 示 是 否 将 图 片 存储 到 实例 的 根 目录 下 。 


Er so 


图 1.88 插入 不 在 同一 驱动 器 上 的 文件 时 给 出 的 提示 信息 


当 单 击 “ 是 ”按钮 时 ， 即 可 将 图 片 复制 到 实例 的 根 目 录 下 。 但 是 ， 这 种 做 法 有 一 个 弊端 ， 就 是 文件 的 存储 
没有 规范 性 。 试 想 一 下 ， 如 果 网 页 中 需要 插入 多 个 图 片 ， 程 序 的 根 目录 下 将 会 是 一 个 什么 景象 ? 所 以 最 好 的 方 
法 是 先 将 要 插入 的 图 片 存储 到 实例 根 目录 下 的 一 个 指定 文件 夹 中 ， 这 样 做 比较 规范 ， 也 容易 管理 ， 一 般 都 将 这 
个 图 片 存储 文件 夹 命名 为 images。 

如 果 在 图 1.88 的 提示 信息 中 ， 单 击 “ 和 否 ”按钮 ， 虽 然 图 片 仍然 可 以 插入 到 表格 中 ， 但 在 查看 网 页 代码 时 会 
发 现 ，img 标签 中 sr 属性 指定 的 图 片 文件 路 径 是 本 机 的 绝对 路 径 〈file:WEI/Program Files/ 9.gif) ， 在 本 机 中 仍 
然 可 以 运行 ， 但 要 将 本 实例 复制 到 其 他 机 器 上 运行 的 话 ， 在 指定 的 路 径 下 将 找 不 到 图 片 文件 。 

设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 请 参考 实例 021， 这 里 不 再 费 述 ， 下 面 介绍 如 何在 创建 好 的 表格 中 
插入 图 片 。 

(1) 首先 ， 将 要 使 用 的 图 片 复 制 到 本 实例 根 目录 下 的 images 文件 夹 中 。 

(2) 将 光标 定位 到 指定 要 插入 图 片 的 单元 格 中 ， 单 击 Dreamweaver 开发 工具 中 的 “插入 ”按钮 ， 在 弹出 的 
列表 框 中 选择 “图 像 ”命令 ， 在 弹出 的 “选择 图 像 源 文件 ”对 话 框 中 ， 选 择 要 插入 的 图 片 ， 如 图 1.89 所 示 。 
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图 1.89 插入 图 片 
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(3) 确定 要 插入 的 图 片 之 后 ， 在 图 1.89 中 单 击 “ 确 定 ” 按 钮 ， 即 完成 图 片 的 插入 操作 。 
(4) 保存 文件 ， 在 正 浏览 器 中 输入 网 址 ， 即 可 运行 本 实例 ， 运 行 结果 请 参看 实例 说 明 。 
图 秘笈 心 法 
心 法 领悟 022: 操作 Dreamweaver 小 技巧 。 


在 Dreamweaver 的 设计 模式 下 ， 当 选中 插入 的 图 片 时 ， 在 开发 工具 的 下 方 将 出 现 图 像 的 属性 对 话 框 ， 如 
图 1.90 所 示 。 通 过 这 个 属性 对 话 框 可 以 设置 图 像 的 宽度 、 高 度 、 链 接 以 及 是 否 添加 地 图 等 。 
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图 1.90 图 像 的 属性 操作 界面 
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力 实例 说 明 


本 实例 讲解 如 何在 Dreamweaver 中 创建 表单 。 表 单 是 网 站 与 客户 沟通 的 一 座 桥 梁 ， 通 过 它 可 以 直接 将 客户 
的 信息 反馈 给 网 站 的 管理 者 ， 达 到 企业 与 网 站 浏览 者 更 好 的 交互 效果 。 在 本 实例 中 将 对 在 Dreamweaver 中 创建 
表单 进行 详细 讲解 ， 本 实例 的 运行 结果 如 图 1.91 所 示 。 
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图 1.91 创建 表单 元 素 


图 关键 技术 


在 Dreamweaver 中 创建 表单 ， 首 先 要 在 工具 栏 中 选择 “表单 ”选项 ， 然 后 就 可 以 通过 不 同 的 按钮 创建 不 同 
的 表单 元 素 ， 其 中 每 个 按钮 对 应 的 功能 如 表 1.1 所 示 。 


表 1.1 Dreamweaver 中 的 表单 元 素 
图 像 | 名 称 说 了 明 


<form name="form?2" method="post" action=""></form> 
name: 表单 的 名 称 

method: 表单 提交 的 方法 ， 包 括 POST 和 GET 方法 
action: 表单 提交 的 路 径 
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续 表 
说 了 明 
<input type="text" name="textfield"> 
type: 应 用 表单 的 类 型 
name: 文本 框 的 名 称 


隐藏 域 


<input type="hidden" name="ID" value=""> 
type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 
name: 隐藏 域 的 名 称 ， 可 以 自己 定义 

Value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 


| 


文本 区 域 


复 选 框 


单 选 按钮 


<textarea name="" cols="" rows="" id=""></textarea> 

<textarea>...</textarea>， 文 本 域 的 标记 

name: 文本 域 的 名 称 ， 例 如 其 中 的 “test” 

cols: 表示 文本 域 字符 的 宽度 

rows: 表示 有 多 少 行 字符 

初始 值 在 <textarea></ textarea> 标 记 之 间 进 行 输入 ， 例 如 其 中 的 “欢迎 大 家 访问 我 们 的 论坛 ” 
<input type="checkbox" name="checkbox" value=" 体 育 "> 

type: 表单 的 类 型 ， 其 中 的 “checkbox” 表 示 复 选 框 

name: 复 选 框 的 名 称 ， 例 如 其 中 的 checkbox 

value: 复 选 框 提交 的 值 ， 例 如 其 中 的 体育 

checked: 如 果 希 望 预先 为 用 户 勾 选 某 些 选项 ， 可 以 为 这 些 选项 加 上 checked 参数 
disable:; 如 果 希 望 某 一 个 选项 失效 ， 可 以 加 上 disabled 参数 

<input type="radio" name="radiobutton" value="radiobutton" checked="checked" /> 男 
<input ="radio" name="radiobutton" value="radiobutton" /> 女 


单 选 按钮 组 


<input type="radio" name="RadioGroupl" value=" 单 选 " /> 单 选 
<input type="radio" name="RadioGroup1" value=" 单 选 " /> 单 选 


<select name="select2"> 
<option selected="selected"> 默 认 值 </option> 
<option value=" 对 应 值 1"> 列 表 值 1</option> 
<option value=" 对 应 值 2"> 列 表 值 2</option> 


国 列表 \ 菜 单 
</select> 
name: 指 该 <select> 组 件 的 名 称 
option: 提供 给 用 户 选 择 的 项 目 ， 其 中 的 value 是 该 选项 所 代表 对 应 的 选择 值 ， 可 以 省 略 
<select name="menul" onchange="MM jumpMenu('‘parent'.this.0)"> 
<option>unnamed1</option> 
这 号 转 末 单 </select> 
跳 转 菜单 ， 通 过 表单 实现 指定 网 址 之 间 的 跳 转 
贺 像 域 <input type="image" name="imageField" src="images/QQ.gif"' /> 在 表单 中 插入 图 片 
回 文件 域 <input type="file" name="file" /> 完成 文件 的 提交 
<input type="submit”name="Submit”value=" 提 交 ”/> 创 建 的 提交 按钮 ， 如 果 stype 的 值 为 
ed 按钮 button， 那 么 它 表示 一 个 普通 的 按钮 ， 不 具备 提交 的 功能 
<input type="reset" name="Submit2" value=" 重 置 " /> 创建 的 重 轩 按钮 
Gl 标签 <label> 标 签 </label> 
口 字段 集 <fieldset><legend> 字 段 集 </legend></fieldset> 
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图 设计 过 程 
在 Dreamweaver 中 创建 表单 的 操作 步骤 如 下 : 


(1) 新 建 一 个 动态 php 文件 ， 切 换 到 设计 模式 下 。 
(2) 在 工具 栏 中 选择 “表单 ”命令 ， 如 图 1.92 所 示 。 


(EDI a 
1.92 ”选择 表单 工具 
(3) 添加 一 个 form 表单 ， 如 图 1.93 所 示 。 
项 回 | 器 关 导 | 同 本 下 | 男 画 | 国画 品 | 可 总 
1.93 添加 表单 
(4) 根据 实际 需要 ， 添 加 不 同 的 表单 元 素 ， 并 设置 相应 的 名 称 和 值 ， 如 图 1.94 所 示 。 
rl 
图 1.94 添加 表单 元 素 
最 终 创 建 的 表单 元 素 设计 效果 如 图 1.95 所 示 。 
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图 1.95 表单 元 素 的 设计 效果 


图 秘笈 心 法 


心 法 领悟 023: 通过 表单 传 值 时 的 注意 事项 。 

在 通过 表单 中 的 元 素 传递 值 的 时 候 ， 一 定 要 正确 地 书写 表单 元 素 的 名 称 ， 其 中 不 应 该 有 空格 存在 ; 在 获取 
表单 元 素 的 值 时 ， 表 单元 素 的 名 称 一 定 要 与 form 中 设置 的 名 称 相 同 ， 同 时 还 要 注意 大 小 写 的 统一 ， 否 则 将 不 能 
获取 到 表单 元 素 的 值 。 


中 级 | 
趣味 指数 : AA 


力 实例 说 明 


本 实例 讲解 如 何在 Dreamweaver 中 创建 和 附加 CSS 样式 。 通过 CSS 能 够 更 好 地 对 网 页 中 的 表格 、 文本 和 图 
像 的 样式 进行 控制 ， 并 且 使 其 更 易于 维护 和 更 新 。 本 实例 的 运行 结果 如 图 1.96 所 示 。 
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编程 词典 言传 语 总 结 


| 1 计算 机 语言 中 的 “新 华 字 奥 ” .具备 海 且 的 天 构 源 ,各 助 您 解决 在 学 习 篇 
乍 香 言 中 通 到 的 问题 - ( 知识 


(2) 拒 程 者 的 良 俩 益友 - 为 祭 的 学习 提供 完整 的 学 习 方案 ， 抬 您 提 供 理论 和 实践 相 结 合 
的 宙 会 ~ ( 字 习 方法 、 实 讽 、 实 吴 等 习 ) 


《 3 ) 邓 来 主义 的 倡导 者 人 i 程序 和 软件 资 
天 ,可 以 作为 参 填 ,也 可 以 直接 使 用 


(4) 完美 的 芋 后 服务 和 交互 方式 ~ 9q、 电 话 、 ERAIL 


1.96 Dreamweaver 中 创建 和 附加 CSS 样式 


图 关键 技术 


在 Dreamweaver 中 创建 CSS 样式 ， 必 须 明确 新 建 CSS 样式 的 规则 ， 如 图 1.97 所 示 。 
Ee 


Em 
CE 于 | 


宕 六 在 。 W 计 他 式 家 文件 ) 也 
他 忆 对 该 文档 


bs] 


图 1.97 新建 CSS 规则 

如 果 选 择 的 是 “新 建 样式 表 文 件 ”选项 ， 那 么 定义 的 CSS 存储 于 指定 的 文件 夹 下 ; 如 果 选 择 的 是 “ 仅 对 该 
文档 ”选项 ， 那 么 定义 的 CSS 存储 于 该 文件 中 。 

如 果 只 是 对 单独 的 某 个 文件 进行 操作 ， 建 议 将 CSS 定义 到 当前 文件 中 ， 但 是 ， 如 果 是 在 网 站 中 应 用 CSS， 
那么 应 该 将 CSS 样式 定义 到 单独 的 文件 中 ， 并 且 以 类 的 形式 进行 定义 ， 因 为 这 样 便于 对 CSS 样式 的 修改 ， 使 网 
站 的 样式 更 加 统一 ， 而 且 可 以 避免 代码 的 元 余 。 

图 设计 过 程 

创建 一 个 名 称 为 styles 的 样式 ， 将 其 定义 到 新 建 样式 表 中 ， 使 用 类 的 形式 进行 定义 ， 其 具体 的 操作 步骤 
如 下 : 

(1) 在 Dreamweaver 的 设计 模式 下 ， 单 击 右键 选择 “CSS 样式 ”/“ 新 建 ” 命 令 ， 在 弹出 的 “新 建 CSS 规 
则 ”对 话 框 中 定义 CSS 样式 的 规则 ， 如 图 1.98 所 示 。 


(2) 如 图 1.98 所 示 ，CSS 样式 的 规则 定义 完成 ， 单 击 “确定 ”按钮 ， 弹 出 “保存 样式 表 文 件 为 ”对 话 框 ， 
定义 CSS 样式 文件 的 存储 位 置 ， 如 图 1.99 所 示 。 


EE 
WRN 站 点 和 服务 器 
ESEGa ee OF 
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| | 
i Wm 站 上 证 久 中 DNS 的 法拉 EN 于 
1.98 定义 CSS 样式 的 规则 1.99 定义 CSS 样式 表 的 存储 位 置 


(3) 确定 存储 位 置 和 名 称 后 ， 单 击 “ 保 存 ” 按 钮 ， 将 弹出 styles 样式 具体 的 规则 定义 对 话 框 ， 如 图 1.100 
所 示 。 在 其 中 ， 可 以 根据 “分 类 ”， 对 类 型 、 背 景 、 区 块 、 方 框 、 边 框 、 列 表 、 定 位 和 扩展 分 别 进行 定义 ， 单 
击 “ 确 定 ” 按 钮 ，styles 样式 创建 完成 。 
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> 的 css 总则 定义 《在 =tTLes_sss 中 


于 GIFF | 
Es| 


图 1.100 定义 styles 样式 的 规则 


(4) 在 Dreamweaver 的 设计 模式 下 ， 选 中 被 操作 的 内 容 ， 单 击 右键 选择 “CSS 样式 ”命令 ， 即 可 选择 指定 
的 样式 文件 ， 如 图 1.101 所 示 。 


EE TOTEFPCYWTIEIEIES 
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编程 词典 家 传 语 总 结 ， 
上 汪 庆生 本本 寺中 的 “才华 字 页” ”具备 海 县 的 首 儿 坦 沽 ， 硬 有 多 和 在 茸 避 入 可 语言 中 沽 的 站 


《2 7 前 程 首 的 民 师 益友 为 总 的 学 习 提 供 记 整 用 字 习 方 刘 ,给 你 提供 各 沦 和 开关 相 站 全 的 机 会 -《 字 习 广 


和 中 要 从 了 让 问 、 赴 语 症 页面、 程序 和 软件 次 天。 可 习作 广大 芍 。 


图 1.101 应 用 定义 的 CSS 样式 


.GBS 技巧 ， 附加 CSS 样式 文件 。 在 Dreamweaver 的 设计 模式 下 ， 单 击 右键 选择 “CSS 样式 ”/“ 附 加 样式 表 ” 
命令 ,在 弹出 的 “链接 外 部 样式 表 ” 对 话 框 中 ， 选 择 定义 在 指定 文件 夹 下 的 CSS 样式 文件 。 如 果 选 
择 “ 链 接 ” 则 直接 通过 link 标签 链接 到 CSS 样式 文件 ; 如 果 选 择 导 入 ， 则 通过 @import url 导入 指 
定 的 CSS 文件 。 确 立 附 加 的 CSS 样式 文件 后 ， 单 击 “ 确 定 ”按钮 。 


图 秘笈 心 法 


心 法 领悟 024: 在 Dreamweaver 中 创建 CSS 样式 的 相关 说 明 。 


在 Dreamweaver 中 创建 的 CSS 样式 , 可 以 在 代码 模式 下 对 其 进行 修改 , 也 可 以 在 设计 模式 下 对 其 进行 修改 ， 
如 图 1.102 所 示 。 


1.102 在 设计 模式 下 操作 CSS 样式 


ed 


中 级 
趣味 指数 :言语 商家 ， 


图 实例 说 明 


在 Dreamweaver 中 不 但 可 以 创建 表格 、 表 单 或 者 CSS 样式 等 内 容 ， 而 且 可 以 通过 行为 ， 实 现 一 些 特殊 的 功 
能 。 例 如 ， 在 本 实例 中 ， 定 义 一 个 “弹出 信息 ”行为 ， 当 用 户 单 击 指定 的 图 片 时 ， 将 弹出 一 个 提示 对 话 框 ， 如 
图 1.103 所 示 。 


,Te i 的 个 人 博客 
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图 节选 择 : 
头 重 连 笃 : 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公 司 


图 1.103 通过 Dreamweaver 直接 创建 的 弹出 信息 


图 关键 技术 


在 Dreamweaver 中 控制 弹出 信息 的 原理 是 自动 创建 JavaScript 脚本 文件 ， 定 义 方法 ， 然 后 通过 onclick 调用 
脚本 中 的 方法 ， 完 成 当 鼠 标 单 击 指定 的 内 容 时 弹出 信息 。 

JavaScript 脚本 中 定义 的 方法 如 下 : 

eal 

VA 

alert(msg): 


人 -> 
</script> 
在 表单 的 图 像 域 中 ， 通 过 onclick 事件 完成 对 脚本 文件 方法 的 调用 ， 其 代码 如 下 : 
<input name="imageField" type="image" onclick="MM popupMsg(' 请 输入 完整 的 注册 信息 )" src="images/09,jpg" 亡 
图 设计 过 程 
在 Dreamweaver 中 添加 “弹出 信息 ”行为 的 操作 步骤 如 下 : 
(1) 通过 Dreamweaver 新 建 一 个 index.php 文件 ， 创 建 一 个 用 户 注册 页 面 。 
(2) 在 Dreamweaver 的 设计 模式 下 , 选择 用 户 注册 的 图 像 域 , 然后 选择 “窗口 ”/“ 行 为 ”命令 , 在 Dreamweaver 
操作 界面 的 右 侧 将 弹出 如 图 1.104 所 示 的 内 容 。 
(3) 在 图 1.104 所 示 的 页 面 中 ， 单 击 “+” 的 下 标 ， 在 弹出 的 列表 框 中 选择 “弹出 信息 ”命令 ， 将 弹出 如 
图 1.105 所 示 的 “弹出 信息 ”编辑 页 面 ， 在 “消息 ”文本 框 中 定义 弹出 信息 的 内 容 ， 最 后 单 击 “ 确 定 ” 按 钮 ， 
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弹出 信息 的 行为 创建 完毕 。 


本 
es E Es 
取消 
到 才 助 
图 1.104 行为 控制 面板 图 1.105 编辑 弹出 信息 


图 秘笈 心 法 


心 法 领悟 025: 在 Dreamweaver 中 实现 一 些 JavaScript 功能 。 
在 Dreamweaver 中 ，“ 弹 出 信息 ”只 是 众多 行为 中 的 一 个 ， 还 可 以 通过 “窗口 ”中 的 行为 实现 很 多 的 功能 ， 
如 图 1.106 所 示 。 


检查 表单 
设置 号 院 栏 图像 
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调用 Javsseript 
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隐 琴 鱼 出 式 项 间 
预先 要 入 图 像 


1.106 行为 的 功能 展示 


趣味 指数 : 伍 食 伍 侧 | 


力 实例 说 明 


本 实例 将 介绍 Dreamweaver 中 行为 的 另 一 种 功能 一 一 控制 打开 浏览 器 的 窗口 。 通 过 该 功能 可 以 对 打开 的 浏 
览 器 窗口 进行 设置 ， 包 括 窗 口 的 高 度 、 宽 度 以 及 是 否 包 含 导 航 工具 栏 、 地 址 工具 栏 和 菜单 栏 等 ， 本 实例 的 运行 
结果 如 图 1.107 所 示 。 
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图 1.107 Dreamweaver 控制 浏览 器 的 窗口 


第 1 章 开发 环境 


图 关键 技术 

控制 打开 浏览 器 的 窗口 ， 同 样 是 Dreamweaver 中 行为 的 一 种 功能 ， 通 过 该 功能 可 以 控制 网 页 窗口 的 打开 模 
式 ， 例 如 ， 网 页 窗口 中 导航 条 的 使 用 、 滚 动 条 的 使 用 、 地 址 工具 栏 的 应 用 以 及 网 页 窗口 的 大 小 等 。 

行为 中 “打开 浏览 器 窗口 ”的 操作 界面 如 图 1.108 所 示 。 


到 
要 一 se | 
窗口 宽 度 : 所 5 ”窗口 高 度 : FE mn | 


图 1.108 打开 浏览 器 窗口 

图 设计 过 程 

在 Dreamweaver 中 添加 “打开 浏览 器 窗口 ”行为 的 操作 步骤 与 添加 “弹出 信息 ”行为 是 相同 的 ， 唯 一 的 区 
别 是 在 单 击 “+” 的 下 标 时 ， 在 弹出 的 列表 框 中 选择 “打开 浏览 器 窗口 ”命令 ， 将 弹出 如 图 1.108 所 示 的 “打开 
浏览 器 窗口 ”对 话 框 。 
图 秘笈 心 法 

心 法 领悟 026: 在 Dreamweaver 中 屏蔽 标准 按钮 。 

通过 “打开 浏览 器 窗口 ”行为 ， 我 们 可 以 屏蔽 浏览 器 窗口 中 的 标准 按钮 ， 这 个 功能 在 某 些 程序 中 是 非常 有 
用 的 ， 例 如 ， 在 一 些 需要 屏蔽 刷新 功能 的 网 页 中 ， 通 过 “打开 浏览 器 窗口 ”行为 来 实现 是 比较 不 错 的 方法 。 


力 实例 说 明 


本 实例 讲解 如 何在 Dreamweaver 中 创建 站 点 ， 从 而 不 必 在 正 浏览 器 中 输入 地 址 ， 只 需 按 F12 键 ， 即 可 完成 
对 所 创建 程序 的 浏览 操作 。 


图 关键 技术 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 ， 一 定 要 注意 将 本 地 的 HITP 地 址 与 测试 服务 器 中 的 URL 
前 级 统一 ， 即 都 指定 到 站 点 的 根 目 录 下 。 例 如 ， 指 定 HITP 的 地 址 是 http://localhost//mr/01/， 那 么 测试 服务 器 的 
URL 前 缀 也 必须 是 http://localhost//mr/01/ 或 者 http://127.0.0.1//mr/01/。 


图 设计 过 程 

在 Dreamweaver 中 创建 站 点 的 操作 步骤 如 下 : 

(1) 打开 Dreamweaver 开发 工具 ， 选 择 菜单 栏 中 的 “站 点 ”/“ 新 建站 点 ”命令 ， 在 如 图 1.109 所 示 的 对 话 
框 中 添加 站 点 名 称 、 设 置 本 地 根 文件 夹 、 链 接 相 对 于 “站 点 根 目录 ”、 设 置 HTTP 地 址 。 

(2) 在 图 1.109 中 ， 选 择 左 侧 的 “测试 服务 器 ”选项 ， 弹 出 如 图 1.110 所 示 的 “测试 服务 器 ”对 话 框 ， 选 
择 服 务 器 模型 “PHP MYSQL”， 访问 为 “本 地 /网 络 ”， 测 试 服务 器 文件 夹 为 “Fi\PkKhPHP\WWwww\”，URL 前 级 
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为 “http:Wlocalhosy”， 最 后 单 击 “确定 ”按钮 。 
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图 1.109 定义 mr 站 点 图 1.110 配置 测试 服务 器 


(3) mr 站 点 和 测试 服务 器 设置 完毕 后 ， 就 可 以 在 Dreamweaver 下 直接 使 用 快捷 键 F12 来 浏览 程序 了 。 
图 秘笈 心 法 
心 法 领悟 027: 在 Dreamweaver 中 创建 站 点 的 注意 事项 。 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 , 如 果 本 地 的 HTTP 地 址 与 测试 服务 器 中 的 URL 前 级 不 统 
， 那 么 就 不 能 够 通过 F12 键 直接 浏览 程序 。 


和 


| 
实例 028 吉林 指数: doo 


图 实例 说 明 


前 面 实例 讲解 Dreamweaver 自身 功能 的 运用 ， 在 本 实例 中 应 用 Dreamweaver 开发 一 个 最 简单 的 PHP 程序 ， 
即 输出 一 段 欢迎 信息 ， 其 目的 一 是 了 解 PHP 的 语法 规则 ， 二 是 熟悉 Dreamweaver 开发 工具 的 使 用 。 运 行 结果 如 
图 1.111 所 示 。 
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1.111 第 1 个 PHP 程序 


图 关键 技术 


必须 将 通过 Dreamweaver 开发 工具 编写 的 PHP 脚本 存储 到 PHP 开发 环境 指定 的 服务 器 文件 夹 下 才 可 以 
运行 。 


图 设计 过 程 


(1) 打开 Dreamweaver 开发 工具 ， 新 建 一 个 PHP 项 目 ， 如 图 1.112 所 示 。 
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图 Dreamweaver Exnange 


图 1.112 新 建 一 个 PHP 项 目 
(2) 单 击 图 1.112 中 的 PHP 项 目 图 标 ， 打 开 一 个 PHP 项 目 文件 夹 ， 如 图 1.113 所 示 。 


EEC 9 
人 用 日 有 | 目 日 国 -和 @- 台 允 虽 | 四 - 品 


IE EL EE E00 民生 题 Y 档 


a 
ns http:// wv. v3. 01 


pnp | 
|echo “欢迎 起 和 我 们 一 起 学 习 FHP!“ 
[> 


66gy7 
Irnl> sn 


区 ETIEEIECIESITEI RE 


EEC 


on 
ai onal dt 
FrR/1999/xkhtal》 


2 © 


Er 


图 1.113 新 的 PHP 项目 文件 


(3) 在 图 1.113 所 示 的 文件 中 , 首先 定义 文件 的 标题 ，<title> 第 一 个 PHP 程序 </title>, 然后 编写 PHP 代码 ， 
其 代码 如 下 : 


<?php 
echo "欢迎 进入 PHP 的 世界 ! !"; 


> 
PHP 代码 分 析 
“<?php” 和 “?>” 是 PHP 的 标记 对 。 在 这 对 标记 中 的 所 有 代码 都 被 当 作 PHP 代码 来 处 理 。 


echo 是 PHP 中 的 输出 语句 ， 与 ASP 中 的 response.write、 


者 变量 值 。 每 行 代码 都 以 分 号 “;” 结 尾 。 


JSP 中 的 outprint 含义 相同 ， 输 出 字符 串 或 


(4) 保存 文件 ， 单 击 图 1.113 中 的 “文件 ”按钮 ， 选 择 “ 另 存 为 ”命令 ,将 编写 的 文件 保存 在 站 点 的 根 目 
录 www 文件 夹 中 ， 并 命名 为 test.php， 最 后 单 击 “ 保 存 ” 按 钮 ， 如 图 1.114 所 示 。 


图 秘笈 心 法 


心 法 领悟 028: 运行 程序 的 两 种 方法 。 
程序 的 运行 有 两 种 方法 : 第 一 种 ， 直 接 在 Dreamweaver 开发 J 


[ 具 中 ， 按 F12 键 运行 程序 ,第 二 种 , 在 正 浏 


览 器 的 地 址 栏 中 输入 http://127.0.0.1/test.php。 程 序 运 行 的 前 提 是 必须 将 程序 存储 到 服务 器 指定 的 文件 夹 中 。 
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HD: | [es 到 人 名] 
保存 类 型 四) 六 有 文档 (Ce hte 六. Mtal ;4. shtm;# shtml 要 | 职 肖 
| 


1.114 保存 编写 的 PHP 文件 


1.7 Zend Studio 开发 工具 


Zend Studio 是 目前 比较 流行 的 PHP 开发 工具 ， 襄 括 了 编辑 、 调 试 、 配 置 PHP 程序 所 需要 的 客户 及 服务 器 
组 件 ， 尤 其 是 功能 齐全 的 调试 功能 ， 让 PHP 错误 不 再 棘手 。 

Zend Studio 也 有 不 足 之 处 ， 一 是 其 运行 速度 慢 ; 二 是 没有 Dreamweaver 的 界面 设计 功能 ， 只 能 通过 浏览 器 
来 浏览 页 面 设计 效果 ; 三 是 其 是 一 款 收 费 软 件 〈 但 可 以 下 载 试用 版 ) ， 下 载 地 址 为 http://www.zend.conystore/ 
products/zend-studio.php。 


peg 
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实例 029 趣味 指数 : 依依 商 闪 


图 实例 说 明 


在 应 用 Zend Studio for Eclipse 之前， 我 们 有 必要 介绍 一 下 它 的 安装 步骤 ， 因 为 只 有 正确 地 完成 安装 ， 才 能 
够 顺利 地 应 用 。 


力 关键 技术 

在 安装 Zend Studio for Eclipse 的 过 程 中 ,关键 是 安装 内 容 的 选择 、 安 装 位 置 的 选择 和 定义 Zend 支持 的 文件 
格式 ， 这 是 在 安装 过 程 中 必须 注意 的 内 容 。 
图 设计 过 程 

(1) 运行 安装 文件 ， 进 行 安装 准备 工作 ， 如 图 1.115 所 示 。 


hhstalAnywhere 正在 做 安装 准备 
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图 1.115 安装 Zend Studio for Eclipse 的 准备 工作 
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(2) 进入 到 安装 页 面 ， 如 图 1.116 所 示 ， 单 击 Next 按钮 。 
(3) 阅读 服务 器 条 款 ， 选 择 同意 ， 如 图 1.117 所 示 ， 单 击 Next 按钮 进入 下 一 页 面 。 


License Agreement 


nstalnmnere wa gude rou mrougn pe nstatason ol Lond 
Sudo or Edgse-611 


You macancel ma watasason st ny sme by cuumg me cancer 
Domon, 


图 1.116 开始 进行 安装 图 1.117 阅读 服务 条 款 
(4) 选择 安装 内 容 ， 其 中 包括 一 个 Zend 浏览 器 和 Zend Studio， 全 部 勾 选 ， 如 图 1.118 所 示 。 单 击 Next 按 


钮 ， 进 入 到 下 一 页 面 。 
(5) 设置 文件 的 安装 目录 ， 用 户 可 以 任意 指定 安装 位 置 ， 确 定单 击 Next 按钮 进行 下 一 项 操作 ， 如 图 1.119 


所 示 。 


图 1.118 选择 安装 内 容 图 1.119 设置 工具 安装 位 置 


(6) 定义 Zend 支持 的 文件 格式 ， 全 部 勾 选 ， 如 图 1.120 所 示 。 
(7) 确认 安装 信息 ， 如 图 1.121 所 示 ， 单 击 Install 按钮 开始 进行 安装 。 
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1.120 定义 Zend 支持 的 文件 格式 图 1.121 确认 安装 信息 
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(8) 安装 进行 中 ， 如 图 1.122 所 示 。 
(9) 安装 完成 ， 单 击 Done 按钮 ， 如 图 1.123 所 示 。 


图 1.122 ”Zend 安装 进行 中 图 1.123 ”安装 成 功 
这 就 是 Zend Studio for Eclipse 的 安装 ， 过 程 非常 简单 ， 只 是 等 待 的 时 间 较 长 。 
图 秘笈 心 法 
心 法 领悟 029: 选择 工作 空间 。 
运行 Zend Studio for Eclipse， 可 以 选择 “File”/“Switch_ Workspace” 命 令 来 选择 工作 的 空间 ， 或 者 重新 创 
建 工作 空间 ， 如 图 1.124 所 示 。 


到 
Select a workspace 


Zend Studio stores your projects ma folder caled a workspace. 
Choose a Workspace folder to use for th session, 


Workspace: [于 9 司 growse... 
@ [Ee | esl 


图 1.124 创建 工作 空间 
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实例 030 


图 实例 说 明 


本 实例 介绍 如 何 通过 Zend Studio 创建 PHP 项 目 。 在 本 项 目 中 创建 一 个 PHP 文件 ， 通 过 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 其 运行 结果 如 图 1.125 所 示 。 


图 关键 技术 


通过 Zend Studio 编写 PHP 程序 ， 首 先 要 选择 正确 的 工作 空间 ， 如 果 工 作 空间 选择 不 正确 ， 那 么 PHP 的 程 
序 就 无 法 运行 。 
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1.125 ”运行 程序 


(1) 运行 Zend Studio， 首 先进 入 到 Zend Studio 的 欢迎 页 面 ， 如 图 1.126 所 示 。 


lo 
EC3IEOEEEOEEIIOECII 
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Eclipse: 
Getting started 


Working with Code Assist 
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图 1.126 进入 到 Zend Studio 的 欢迎 页 面 


(2) 选择 “文件 ”/“ 切 换 工作 空间 ”/“ 其 他 ”命令 ,设置 工作 空间 ， 将 项 目 保存 在 指定 名 称 的 文件 夹 中 ， 
如 图 1.127 所 示 ， 将 F:\PKhPHP\www 文件 夹 作 为 工作 空间 。 


选择 工作 空间 
EF Stugie for Belips 名 为 某 工作 全 的 文件 夹 中 。 
个 于 于 由 全 证 的 下 的 日 立 件 六 
工人 二 昌 四 : [By 司 _is 四 .| 
， 划 制 设 秆 开 ) 


@ Cw ] w | 
1.127 选择 工作 空间 
(3) 接 下 来 进入 Zend Studio 的 工作 台中 ， 如 图 1.128 所 示 。 
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图 1.128 Zend Studio 的 工作 台 


(4) 创建 一 个 PHP 项目。 选择 “文件 ”/“ 新 建 ”/“PHP Project” 命 令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.129 
所 示 。 
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图 1.129 创建 PHP 项 目 


(5) 进入 到 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 
值 ; 选择 PHP 的 版 本 ， 设 置 是 否 支持 JavaScript 脚本 ， 如 图 1.130 所 示 。 


= 加 当 
Now PHP Project 


ns 加 设置 工程 名 称 


回 定 义工 作 空间 
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图 1.130 新 建 工程 
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(6) 在 项 目 01 中 创建 PHP 文件， 如 图 1.131 所 示 。 
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图 1.131 创建 PHP 文 件 
在 图 1.129 所 示 的 操作 步骤 中 ， 不 但 可 以 创建 PHP 文件 ， 还 可 以 创建 hml、CSS、JavaScript 和 XML 文件 
等 ， 具 体 可 以 根据 程序 的 实际 情况 进行 创建 。 
(7) 进入 到 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 “ 完 成 ”按钮 ， 如 图 1.132 所 示 。 
EDUDOITOI -iox 
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图 1.132 创建 ndex.php 文件 
(8) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 ， 如 图 1.133 所 示 。 


四国 ndexphp 
国 柄 Prp hdude path 
四 一 Prp Langusoe Lbrar| 


Theouput may be 
eo mae ot hy 


区 


-|l | sl [EE Foens Tests | corsoe [WR Servers [9s ouput Es 


1.133 ”编辑 PHP 代码 
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如 图 1.133 所 示 ，Zend Studio for Eclipse 工具 最 大 的 优点 就 是 代码 提示 功能 ， 它 可 以 在 用 户 输 入 部 分 PHP 
脚本 语言 时 ， 给 出 相关 PHP 脚本 语言 的 提示 供 选 择 。 这 里 应 用 phpinfo0 函 数 ， 获 取 PHP 的 相关 配置 信息 。 
(9) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 峰 | 掖 钮 ， 运 行程 序 ， 运 行 结果 可 以 参看 实例 说 明 。 


力 秘笈 心 法 


心 法 领悟 030: Zend Studio 对 Zend Framework 框架 的 支持 。 
通过 Zend Studio 不 但 可 以 创建 PHP 项 目 ， 而 且 可 以 直接 生成 Zend Framework 框架 ， 开 发 者 不 必 再 为 搭建 
Zend Framework 框架 而 头疼 。 


国 实例 说 明 


在 Zend Studio 中 同样 可 以 控制 创建 项 目 、 文 件 的 编码 格式 。 至 于 编码 格式 选择 的 重要 性 这 里 就 不 再 歼 述 ， 
直接 介绍 如 何在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 。 如 果 通 过 Zend Studio 打开 一 个 编码 格式 不 匹配 的 
文件 ， 那 么 输出 结果 将 如 图 1.134 所 示 。 


TYPE html PUBLIC "-//W3C//DTD XHTNL 1.0 Transitional//EN” ™ 
xmlnse "http://www. w3. org/1999/xhtml "> 


http-equive "Content -Type" content="text/html; charset=utf- 

reamweaver 钥 y 壕 娴 地 ” 持 儿 才 寮 8 给 桶 用 </cicle> 
href="css/styles.css" rel="stylesheet" type="text/css" / 
pt type="text/Javascript"> 


9 function NM_popuplsg(msg) { //v1i.0 
alert (msg); 


图 1.134 编码 格式 不 正确 导致 乱码 


图 关键 技术 


在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 ， 关 键 是 从 根本 着 手 ， 也 就 是 说 要 控制 一 个 项 目 中 文件 的 编码 
格式 ， 只 要 项 目 本 身 的 编码 格式 确立 ， 那 么 创建 的 文件 的 格式 自然 是 与 项 目 相同 的 。 
力 设计 过 程 

(1) 在 Zend Studio 中 要 设置 项 目的 编码 格式 ， 首 先 就 要 创建 一 个 项 目 。 有 关 项 目 创建 的 具体 步骤 请 参看 
实例 030， 这 里 不 再 袭 述 。 

(2) 项 目 创 建成 功 后 ， 选 中 创建 的 项 目 ， 单 击 右键 ， 在 弹出 的 菜单 中 选择 “Properties” 命 令 ， 将 弹出 如 
图 1.135 所 示 的 对 话 框 。 

(3) 在 图 1.135 所 示 的 对 话 框 中 ， 选 中 “Other” 单 选 按钮 ， 在 其 下 拉 列 表 中 选择 指定 的 编码 格式 ， 最 后 单 
击 OK 按钮 ， 项 目 编码 格式 即 设置 完成 。 
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图 1.135 设置 项 目的 编码 格式 


图 秘笈 心 法 


心 法 领悟 031: 在 Zend Studio 中 修改 编码 格式 。 

在 实例 说 明 中 我 们 曾 看 到 一 个 编码 格式 不 匹配 的 文件 打开 的 效果 ， 那 么 如 何 对 这 个 文件 的 编码 格式 进行 修 
改 呢 ? 

首先 ， 打 开 编码 格式 不 匹配 的 文件 。 然 后 ， 单 击 Edit 按钮 ， 在 弹出 的 菜单 中 选择 “Set Encoding” 命 令 ， 将 
弹出 如 图 1.136 所 示 的 对 话 框 ， 在 这 个 对 话 框 中 选中 “Ohter” 单 选 按钮 ， 设 置 这 个 文件 的 编码 格式 。 最 后 ， 单 
击 OK 按钮 。 


力 实例 说 明 


在 Zend Studio 中 ， 通 过 快捷 键 可 以 完成 很 多 操作 ， 快 捷 键 的 运用 可 以 为 开发 者 节省 很 多 时 间 ， 而 且 可 以 简 
化 操作 的 流程 。 在 本 实例 中 将 介绍 如 何 运用 Zend Studio 中 的 快捷 键 创建 PHP 项 目 。 


图 关键 技术 


要 应 用 Zend Studio 中 的 快捷 键 , 必须 了 解 快捷 键 代表 的 意义 .在 Zend Studio 中 , 单 击 Help 按钮 , 选择 “Key 
Assist...” 命 令 将 弹出 Zend Studio 中 的 快捷 键 列表 , 或 者 也 可 以 直接 按 CtrlH+Shift+L 键 , 同样 可 以 弹出 快捷 键 列 
表 。 在 这 个 列表 中 可 以 查看 到 所 有 快捷 键 代表 的 意义 ， 如 图 1.137 所 示 。 
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Colapse CiHNumpad_Subtract 
Colapse Ml Cul+Shift rNumpad_Divide 


图 1.137 Zend Studio 中 的 快捷 键 列表 


图 设计 过 程 


(1) 在 Zend Studio 中 创建 一 个 PHP 项目。 可 以 直接 使 用 快捷 键 AltrShiftHN, 将 弹出 一 个 列表 , 选择 “PHP 
Project” 命 令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.138 所 示 。 
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图 1.138 创建 PHP 项 目 


(2) 进入 到 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 
值 ; 选择 PHP 的 版 本 ， 设 置 是 否 支持 JavaScript 脚本 ， 如 图 1.139 所 示 。 

(3) 在 项 目 01 中 创建 PHP 文件 。 编 写 一 个 简单 实例 ， 同 样 可 以 使 用 快捷 键 Alt+ShifttYN， 只 是 要 在 列表 中 
选择 “PHP File” 命 令 ， 如 图 1.140 所 示 。 

(4) 进入 到 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 “ 完 成 ”按钮 ， 完 成 文件 的 创建 ， 如 图 1.141 

(5) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 。 在 编辑 区 中 可 以 通过 快捷 键 Ctl+ShiftrtF 对 代 
码 进行 格式 化 ， 如 图 1.142 所 示 。 
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图 1.139 新 建 工 程 


图 1.140 创建 PHP 文 件 
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图 1.141 创建 ndexphp 文件 
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1.142 编辑 PHP 代码 


(6) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 网 按钮 ， 运 行程 序 ， 运 行 结果 如 图 1.142 所 示 。 
图 秘笈 心 法 


心 法 领悟 032: 在 Zend Studio 中 使 用 快捷 键 。 
在 Zend Studio 中 ， 对 于 快捷 键 的 使 用 不 必 机 械 的 去 记忆 ， 只 要 了 解 一 些 常用 的 就 可 以 。 对 于 初学 者 来 说 ， 
通过 鼠标 进行 操作 比 使 用 快捷 键 更 好 ， 更 有 助 于 对 工具 功能 的 理解 和 学 习 。 


实例 033 


图 实例 说 明 


在 运行 PHP 程序 的 过 程 中 , 需要 将 PHP 程序 复制 到 Apache 服务 器 指定 的 根 目录 下 , 然后 在 正 浏 览 器 的 地 
址 栏 中 输入 http:/127.0.0.1/ 或 者 http://localhost/ 来 运行 PHP 程序 。 而 在 Zend Studio 中 可 以 直接 部 署 Apache 服 
务 器 ， Was PHP 程序 ， 其 运行 结果 如 图 1.143 所 示 。 
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图 1.143 运行 程序 
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图 关键 技术 


在 Zend Studio 中 部 署 Apache 服务 器 ， 关 键 是 指定 正确 的 访问 路 径 ， 如 图 1.144 所 示 。 
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图 1.144 部 署 Apache 服务 器 的 访问 路 径 


如 果 在 图 1.144 所 示 的 界面 中 ， 没 有 指定 URL 中 访问 文件 的 具体 位 置 MR/01/001， 那 么 程序 就 不 能 正常 运 
行 ， 将 出 现 如 图 1.145 所 示 的 效果 。 
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本 
单 击 @@ 囊 雪 ， 寻找 Tnternet 上 的 信息 
ITP 404 - 未 找到 文件 
Internet Explorer 


图 1.145 错误 的 设置 访问 路 径 
设计 过 程 
在 Zend Studio 中 部 署 Apache 服务 器 的 操作 步骤 如 下 : 
(1) 创建 一 个 PHP 项 目 ， 这 里 不 再 歼 述 。 


(2) 单 击 工 具 栏 中 日 “按钮 的 三 角 标 ， 将 弹出 一 个 列表 框 ， 选 择 Run Configurations 选项 ， 在 弹出 的 对 话 杠 
中 完成 对 Apache 服务 器 的 部 署 ， 包括 文 件 的 指定 ， 如 图 1.146 所 示 。URL 访问 路 径 的 设置 ， 如 图 1.147 所 示 。 
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rm 
厂 sate Generate 
Ti 一 -一 
[二 hl Browse wL: i /W/o1/001/index. php 


图 1.146 设置 访问 文件 1.147 设置 URL 访问 路 径 


(3) 设置 完成 后 单 击 Run 按钮 ， 即 可 浏览 PHP 项 目 中 的 内 容 。 
图 秘笈 心 法 


心 法 领悟 033: 在 Zend Studio 中 修改 快捷 键 的 设置 。 


单 击 Window 按钮 ， 选 择 “Preferences” 命 令 ， 将 弹出 如 图 1.148 所 示 的 对 话 框 ， 可 以 在 此 对 话 框 中 完成 对 
快捷 键 的 修改 操作 。 


T Bindine Te IT 
AtHSNiEtt Ta Windors ET 


二 | 


security 
Service Felicits 
EB Startap and Shutdowa 
Yeb Brovser 
EYorkspace 
由 Dats Ilanagwment 


CulrShifuty 
CerlySha fttT 
CerlySHittT 
CerlySNi RT 


时 
用 Dyanie langoagas Eopy Comnard | Wabind Camani | Restore Coeeand 
了 
Hne: armat 
Deseriptien: ss Coglicts 
ER 1 下 
由 Tasks 
Br ha em mi 可 
Vaiauim 
eb a 
由 Wib Serviets 
Restore Defaults 


EE 
图 1.148 ”Zend Studio 中 快捷 键 的 修改 步骤 


Ph 
Ph 
Ph 
Ph 
Ph 
Ph 
Ph 
Ph 
Ph 
Ph 


Ph 


其 本 语法 
运算 符 
包含 语句 
条 件 语句 
循环 控制 | 
跳 转 语句 

自 定 义 图 数 
字符 此 
正则 表达 式 
数组 

日 期 和 时 间 
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2.1 基本 语 


也 许 你 是 一 个 PHP 初学 者 ， 当 你 向 有 经 验 的 PHP 高 级 程序 员 请 教 如 何 学 好 PHP 这 门 语 言 时 ， 想 必 他 会 问 
你 有 没有 其 他 编程 语言 的 基础 ， 如 果 有 的 话 ， 就 能 够 很 快 入 门 ， 学 起 来 也 很 轻松 。 

由 此 可 见 ， 掌 握 一 门 语言 是 多 么 的 重要 。 可 以 说 ， 扎 实 的 语言 基础 ， 是 培养 和 提高 程序 员 编程 能 力 的 基本 
途径 ,语言 基础 也 是 学 习 PHP 过 程 中 非常 重要 的 一 个 环节 , 它 在 很 大 程度 上 决定 了 程序 员 PHP 学 习 的 进展 效果 。 

另外 ， 程 序 员 的 创造 力 极 强 ， 可 以 完全 按照 自己 的 设计 目标 和 思路 组 织 代码 ， 用 与 其 他 程序 员 完 全 不 同 的 
设计 方法 实现 完全 相同 的 功能 。 但 是 ， 编 程 同 时 也 是 一 项 十 分 严谨 的 工作 ， 因 为 语法 是 严格 限定 的 ， 代 码 必须 
i el 规范 的 代码 都 不 能 被 计算 机 执行 ， 哪 怕 是 程序 员 写 错 一 个 字母 ， 或 者 
少 写 一 个 结束 符 都 会 使 程序 出 错 。 

所 以 ， 程序 设计 语言 的 语法 必须 得 到 必要 的 重视 。 语 法 是 PHP 语言 的 规则 ， 打 好 这 个 基础 ， 循 序 渐进 地 学 
习 ， 实 际 运用 时 才 会 得 心 应 手 。 


高 级 
起 休 彬 名 :本 机 全 | 


图 实例 说 明 


本 实例 应 用 PHP 的 标记 通过 echo 语句 和 phpinfo0 函 数 ， 向 用 户 展示 PHP 的 配置 信息 ， 包 括 配 置 文件 所 在 
的 目录 以 及 一 些 相关 扩展 库 的 版 本 、 作 者 信息 等 。 运 行 结果 如 图 2.1 所 示 。 


cscript jnologo configure js "--enable-snapshot-build" "--with-gd=shared" "with-extra-includes=C:\Program Files (x86) 
Wicrosoft SDKYIncude;C PROGRA~2WMICROS~2IVCS8\ATLUNCLJDE;C: 


和 | fp, compress.zib 


三 ee 
Socket Transports 
上 Convertjiconw +, string rot13, Shingtoupper string ,tolower, string,strip_tags, convert,*, consumed, zib,* 


图 2.1 PHP 配置 信息 
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图 关键 技术 
本 实例 的 关键 点 是 应 用 PHP 的 输出 语句 echo， 输 出 phpinfo0 函 数 的 返回 值 。phpinfo0 函 数 的 代码 如 下 : 
int phpinfo ( [int what]); 
该 函数 将 输出 PHP 的 配置 信息 。 

图 设计 过 程 
全 时 index.php 文件 ， 写 PHP 标记 ， 通 过 echo 语句 输出 phpinfo0 函 数 的 返回 值 ， 其 代码 如 下 : 
Senpa0， /输出 PHP 配 置信 息 


图 秘笈 心 法 

心 法 领悟 034: phpinfo0 函 数 的 具体 应 用 。 

在 实际 的 PHP 项 目的 开发 过 程 中 ， 用户 加 载 的 任何 一 个 组 件 ， 在 phpinfo0 函 数 的 输出 页 面 中 都 会 显示 是 否 
已 经 获得 支持 ， 所 以 此 函数 的 应 用 对 于 一 个 初学 者 来 说 是 十 分 重要 的 。 


实例 035 


趣味 指数 : 食 食 容 窗 


图 实例 说 明 

在 用 PHP 编写 的 网 站 中 ， 经 常 需要 获取 当前 时 间 。 例 如 用 户 在 什么 时 间 登 录 的 网 站 、 黑 客 攻击 网 站 是 在 什 
么 时 间 等 。 本 实例 应 用 PHP 标记 ， 通 过 echo 语句 和 date(O) 函 数 来 实现 获取 服务 器 时 间 ， 并 进行 打印 。 运 行 结果 
如 图 2.2 所 示 。 


当前 和 统 时 间 是 8 2010-05-27 010856857 


图 2.2 系统 当前 时 间 


图 关键 技术 


本 实例 主要 是 通过 date0 函 数 获取 系统 的 格林 威 治 时 间 ， 其 语法 及 说 明 如 下 : 
date(string format,int timestamp): 
date0: 参数 format 指定 日 期 和 时 间 输 出 的 格式 。 有 关 参 数 format 指定 的 格式 如 表 2.1 所 示 。 参数 timestamp 
为 可 选 参数 ， 指 定时 间 戳 ， 如 果 没 有 指定 时 间 蕉 ， 则 使 用 本 地 时 间 time0。 
表 2.1 参数 format 的 格式 化 选项 
参数 说 有明 
a | 小 写 的 上 午 和 下 午 值 ， 返 回 什 am 或 pm 
A | 大 写 的 上 午 和 下 午 值 ， 返 回 值 AM 或 PM 
B | Swatch Intemet 标准 时 间 ， 返 回 值 000~999 
qd | 月 份 中 的 第 几 天 ， 有 前 导 零 的 2 位 数字 ， 返 回 什 01-31 


D 星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 Mon~Sun 
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续 表 
参 数 说 了 明 
F 月 份 ， 完 整 的 文本 格式 ， 返 回 值 January 到 December 
g 小 时 ，12 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 1~12 
G 小 时 ，24 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 0~23 
i 有 前 导 零 的 分 钟 数 ， 返 回 值 00~59 
I 判断 是 否 为 夏令 时 ， 如 果 是 夏令 时 返回 值 为 1， 否 则 为 0 
j 月 份 中 的 第 几 天 ， 没 有 前 导 零 ， 返 回 值 1~31 
1 星期 数 ， 完 整 的 文本 格式 ， 返 回 值 Sunday~Saturday 
L 判断 是 否 为 闵 年 ， 如 果 是 六 年 返回 值 为 1， 否则 为 0 
m 数字 表示 的 月 份 ， 有 前 导 零 ， 返 回 值 01~12 
M 
n 
0 


3 个 字母 缩写 表示 的 月 份 ， 返 回 值 Jan~Dec 

数字 表示 的 月 份 ， 没 有 前 导 零 ， 返 回 值 1~12 

与 格林 威 治 时 间 相差 的 小 时 数 ， 如 0200 

RFC 822 格式 的 日 期 ， 如 Thu，21 Dec 2000 16: 01: 07 +0200 
秒 数 ， 有 前 导 零 ， 返 回 值 00~59 


~ 


S 

S 每 月 天 数 后 面 的 英文 后 级 ， 两 个 字符 ， 如 st、nd、rd 或 者 也， 可 以 和 j 一 起 使 用 

指定 月 份 所 应 有 的 天 数 

T 本 机 所 在 的 时 区 

U 从 UNIX 纪元 (January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 

Ww 星期 中 的 第 几 天 ， 数 字 表示 ， 返 回 值 为 0~6 

Ww ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 

y 2 位 数字 表示 的 年 份 ， 返回 值 如 88~08 

交 4 位 数字 完整 表示 的 年 份 ， 返 回 值 如 1998、2008 

z 年 份 中 的 第 几 天 ， 返 回 值 0~366 

吕 时 差 偏 移 量 的 秒 数 。UTC 西边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 ， 返 回 值 ; 
-43200-43200 


设计 过 程 
创建 index php 文件 ， 通 过 echo 语句 输出 date0 函 数 的 返回 值 ， 其 代码 如 下 : 


<?php 
echo date(‘Y-m-s H:i:s’); // 输 出 当前 时 间 
> 


图 秘笈 心 法 

心 法 领悟 035: 对 系统 时 间 的 设置 。 

看 了 上 面 的 实例 ， 读 者 也 许 会 感到 奇怪 ， 为 什么 系统 当前 的 时 间 比 正常 的 时 间 少 了 8 个 小 时 ? 原因 是 系统 
输出 的 当前 时 间 是 系统 默认 的 格林 威 治 时 间 ， 而 不 是 我 们 所 使 用 的 东 八 区 的 北京 时 间 。 

想 要 更 改 为 东 八 区 的 时 间 ， 有 两 种 方法 : 

(1) 修改 php.ini 文件 中 的 设置 ， 找 到 [date] 下 的 “:datetimezone = ”选项 ， 将 该 项 修改 为 “date.timezone 
=Asia/Hong Kong”， 然 后 重启 Apache 服务 器 。 
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(2) 在 程序 中 ， 通 过 在 使 用 日 期 格式 之 前 添加 “date_default_timezone_set(timezone);” 函 数 来 完成 对 时 区 
的 设置 。 参数 timezone 为 PHP 可 识别 的 时 区 名 称 , 如 果 PHP 无 法 识别 时 区 名 称 , 则 系统 采用 UTC 时 区 在 PHP 
手册 中 提供 了 各 时 区 的 名 称 列表 ， 其 中 北京 时 间 可 以 设置 时 区 为 PRC (中 华人 民 共 和 国 ) 、Asia/Chongqing ( 重 
庆 ) 、Asia/Shanghai (上 海 ) 、Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 间 是 等 效 的 。 


说 明 : 系统 默认 的 格林 威 治标 准时 间 ( Greenwich Mean Time，GMT ) 与 北京 时 间 相差 8 个 小 时 ， 在 国际 无 
线 电 通信 领域 , 使 用 一 个 统一 的 时 间 ， 称 为 通用 协调 时 间 ( Universal Time Coordinated，UTC ) 。UTC 
与 格林 威 治标 准时 间 相 同 。 


设置 完成 后 ， 时 间 显 示 如 图 2.3 所 示 。 


轨 前 交 纺 时 间 是 ;2010.0827 Ry 


2.3 ”系统 设置 后 的 当前 时 间 


了 的 PHP 文件 名 高 级 


上 说 明 


很 多 时 候 用 户 需要 编写 包含 文件 路 径 及 文件 名 称 的 代码 ， 如 果 通 过 目录 查找 ， 未 免 有 些 麻 烦 。 这 时 用 户 可 
以 使 用 _FILE_ 预 定义 函数 。 本 实例 通过 ”FILE_ 预 定义 常量 获取 目标 文件 的 路 径 及 文件 名 称 并 在 网 页 上 进行 
打印 ， 运 行 结果 如 图 2.4 所 示 。 


C\AppServ\Wwww\MR\02\003\index.php 


图 2.4 输出 当前 文件 路 径 和 名 称 


图 关键 技术 

系统 预定 义 常量 和 用 户 自 定义 常量 在 使 用 上 没有 差别 。 大 多 数 预 定义 常量 的 执行 结果 都 是 服务 器 的 相关 信 
息 〈 版 本 号 、 路 径 、 错 误 参 数 等 ) ， 所 以 程序 员 很 少将 此 函数 用 于 网 站 前 台 的 开发 ， 如 果 被 别有用心 的 人 知道 
了 这 些 信 息 ， 会 严重 威胁 服务 器 的 安全 。 使 用 此 函数 的 语法 说 明 如 下 : 

_FILE_ 预 定义 常量 : 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 自 PHP 4.0.2 
起 ，_FILE ”总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 路 径 。 
图 设计 过 程 

创建 index.php 文件 ， 通 过 echo 语句 输出 _FILE 预定 义 常量 ， 其 代码 如 下 : 

<2php 

echo_ FILE ; /获取 文件 的 完整 路 径 


> 


力 秘笈 心 法 


心 法 领悟 036: 预定 义 常量 的 说 明 。 
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PHP 中 可 以 使 用 预定 义 常量 获取 PHP 中 的 信息 ， 常 用 的 预定 义 常 量 如 表 2.2 所 示 。 


表 2.2 ”PHP 的 预定 义 常量 
常 量 名 功 能 
_FIE 默认 常量 ，PHP 程序 文件 名 
_IINE 默认 常量 ，PHP 程序 行 数 
PHP VERSION 内 建 常量 ，PHP 程序 的 版 本 ， 如 3.0.8_dev 
PHP_ OS 内 建 常量 ， 执 行 PHP 解析 器 的 操作 系统 名 称 ， 如 Windows 
TRUE 该 常量 是 一 个 真 值 (tme) 
FALSE 该 常量 是 一 个 假 值 (false) 
NULL 一 个 null 值 
E ERROR 该 常量 指 到 最 近 的 错误 处 
E WARNING 该 常量 指 到 最 近 的 警告 处 
E PARSE 该 常量 指 到 解析 语法 有 潜在 问题 处 
E NOTICE 该 常量 指 到 不 寻常 但 不 一 定 是 错误 处 


< 注意 : 


FILE 和 _LINE_ 中 的 “ 


PHP 的 错误 调试 局 
实例 037 


实例 说 明 


输出 或 定义 字符 串 时 离 不 开 单 引号 和 双 引 
本 实例 应 用 单 引号 与 双 引 号 操作 符 向 用 户 说 明 如 何 区 分 单 引号 和 双 引 号 ， 


图 关键 技术 


本 实例 的 关键 点 是 输出 单 引号 和 双 引 号 修饰 的 字符 串 以 显示 其 区 别 。 


分 。 如 果 想 详细 了 解 ， 请 参考 error TeportingO 函 数 。 


输出 字符 囊 1 
输出 字符 串 9a 


图 2.5 区 分 单 引号 和 双 引 号 


器 


”是 两 条 下 划 线 ， 而 不 是 一 条 “ ”。 表 中 以 下 开头 的 预定 义 常量 是 


趣味 指 妆容 计 商 评 


运行 结果 如 图 2.5 所 示 。 


号 的 修饰 ,表面 上 看 它们 似乎 没有 什么 不 同 ,实际 上 是 有 区 别 的 。 


使 用 双 引 号 与 单 引号 最 大 的 区 别 是 ， 双 引号 中 所 包含 的 变量 会 自动 被 替换 成 实际 数值 ， 而 在 单 引号 中 包含 


的 变量 则 按 普 通 字符 串 输出 。 
图 设计 过 程 


创建 index.php 文件 ， 通 过 echo 语句 输出 用 单 、 双 引号 修饰 的 字符 串 ， 其 代码 如 下 : 
<2php 


$a=1; 
echo "输出 字符 串 $a"."<br>"; 
echo 答 出 字符 串 $a': 


> 


图 秘笈 心 法 


心 法 领悟 037: 转 义 字符 。 
通过 双 引 号 定义 字符 串 ， 可 以 支持 很 多 的 转 义 字符 。 如 表 2.3 所 示 为 双 引 号 支持 的 转 义 字符 。 


表 2.3 双 引 号 支持 的 转 义 字符 


转 义 字符 含义 
un 换行 (LF 或 ASCII 字符 0x0A (10) ) 
Yr 回 车 (CR 或 ASCII 字符 0x0D (13) ) 
上 水 平 制 表 符 (HT 或 ASCII 字符 0x09 (9) ) 
\ 反 和 斜 杠 
\§ 美元 符号 
Ww 单 引 号 
Wy 双 引 号 
\[0-7]{1.3} 此 正则 表达 式 序列 匹配 一 个 用 八进制 符号 表示 的 字符 ， 如 \467 
\x[0-9A-Fa-f] {1.2} 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 符号 表示 的 字符 ， 如 \x9f 


和 在 Windows 系统 中 没有 什么 区 别 ， 都 可 以 当 作 回 车 符 ， 但 在 Linux 系统 中 则 是 两 种 效果 。 在 Linux 


中 ， 表示 换 到 下 一 行 ， 却 不 会 回 到 行 首 ， 而 Y 表示 光标 会 回 到 行 首 ， 但 仍然 在 本 行 。 如 果 读 者 使 用 Linux 操 


作 系 统 ， 可 以 尝试 一 下 这 两 个 转 义 字符 的 应 用 。 


Cg 技巧 ; 


[ED 说 明 : 


在 定义 简单 的 字符 串 时 ， 使 用 单 引号 是 比较 合适 的 处 理 方式 。 如 果 使 用 双 引 号 ，PHP 将 花费 一 些 时 
间 来 处 理 字符 串 的 转 义 和 变量 的 解析 。 因此， 笔者 建议 在 定义 字符 串 时 ， 如 果 没有 特别 的 要 求 ， 应 
该 尽量 使 用 单 引 号 。 通 过 单 引 号 定义 的 字符 串 类 型 变量 按照 普通 字符 进行 输出 。 例 如 ， 通 过 单 引号 
定义 字符 串 “'$result”， 那么 将 输出 “$result”， 而 不 会 输出 变量 $result 的 实际 值 。 


(1) 在 字符 串 中 表示 单 引 号 ， 需 要 使 用 反 斜 线 (\) 进行 转 义 。 例 如 ， 定 义 一 个 字符 串 “Its dogged 
that does it.”， 则 需要 写 出 “It\'s dogged that does it” 。 

(2) 在 单 引号 或 者 字符 串 结束 位 置 表示 反 斜 线 ， 同 样 要 用 反 儿 线 进行 转 义 ， 即 用 两 个 反 针线 (\) 
表示 。 例 如 ， 表 示 字 符 串 “F:\PkhPHP\Wwww”， 则 要 写 出 “F:NPkhPHPNwww”。 


力 实例 说 明 


JavaScript 语言 是 一 门 功能 强大 的 客户 端 脚本 语言 ， 也 是 一 门 跨 平 台 语 言 。PHP 支持 使 用 JavaScript 编码 。 
本 实例 通过 PHP5 新 型 字符 串 动态 输出 JavaScript 代码 ， 运 行 结果 如 图 2.6 所 示 。 


[来自 http://1ocalhost 的 页 面 说 


欢 加 进入 Pig 编 入 世界 t 
业 


图 2.6 动态 输出 JavaScript 代码 
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图 关键 技术 

PHP 5.0 新 型 字符 串 的 使 用 是 本 实例 的 关键 。PHP 5.0 这 种 新 型 的 字符 串 是 以 “<<<” 开 始 ， 后 面 紧 跟着 字 
符 串 开始 标记 ， 之 后 为 字符 串 的 内 容 ， 最 后 以 标记 加 分 号 〈 本 实例 以 “mark” 作 为 结束 标记 ) 结束 。 本 函数 一 
般 用 于 对 HTML 代码 的 格式 输出 。 


图 设计 过 程 
创建 index.php 文件 ， 通 过 PHP5 新 型 字符 串 实现 实例 ， 其 代码 如 下 : 
<?php 
$str=<<<mark WPHPS 新 型 字符 串 开始 部 分 
<script language="javascript" type="text/javascript"> WJavaScript 代 码 
aleatc, 欢 迎 进入 PEP 编程 世界 ! el: /输出 提示 
</script> /| 结束 标记 
mark; /新 型 字符 串 介绍 标记 
echo $str; /输出 字符 串 
图 秘笈 心 法 


心 法 领悟 038: 新 型 字符 串 。 
笔者 认为 ， 新 型 字符 串 是 将 以 往 的 在 HTML 标签 中 嵌 套 PHP 标签 的 方式 ， 做 了 一 次 有 效 的 逆转 。 
高 级 


趣味 指 玫 ， 帘 请 请 请 


力 实例 说 明 


在 PHP 手册 中 经 常会 看 到 一 些 返回 值 为 Boolean 的 函数 ， 函 数 说 明 的 讲解 可 能 是 当 符合 条 件 时 ， 返 回 值 为 


1， 否 则 返回 值 为 0。 按照 正常 的 思维 ， 返 回 值 应 该 是 TRUE 和 FALSE， 因 为 它们 才 是 真正 的 Boolean 类 型 。 其 
实 这 些 都 是 类 型 转换 的 应 用 。 本 实例 介绍 PHP 中 的 数据 类 型 的 知识 ， 展 示 数 据 是 如 何 进行 类 型 转换 的 ， 运 行 结 
果 如 图 2.7 所 示 。 


自动 类 型 转换 
104 我 是 字符 串 型 数据 =10 
强制 类 型 转换 ， 
10+ 我 是 字符 串 型 数据 =10 
图 2.7 当 数 字 遇 到 了 字符 串 


图 关键 技术 

虽然 PHP 是 弱 类 型 语言 ， 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 。 本 
实例 的 关键 点 是 运用 类 型 转换 的 特点 进行 输出 。 

(1) 系统 根据 情况 自动 转换 数据 类 型 称 为 自动 转换 。 

(2) 用 户 在 变量 名 称 前 将 想 要 转换 的 数据 类 型 写 到 括号 内 称 为 强制 转换 。 
图 设计 过 程 


(1) 创建 PHP 脚本 ， 通 过 echo 语句 输出 想 要 转换 的 变量 ， 其 代码 如 下 : 


第 2 章 PHP 基础 


php 
$a= 10; // 整 型 数据 
$b=" 我 是 字符 串 型 数据 "; /字符 串 类 型 数据 
Se= $at Sb; 
$f=$b+ $a; 


echo "自动 类 型 转换 : <br>"; 

echo '10+ 我 是 字符 串 型 数据 =.$e."<br>"; 

echo "强制 类 型 转换 :<br>"; 

echo '10+ 我 是 字符 串 型 数据 =.(string)$e."<br>"; 


> 
(2) 将 文件 存储 于 \MR\02\039\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.7 所 示 。 
图 秘笈 心 法 


心 法 领悟 039: 类 型 转换 的 相关 说 明 。 
(1) 转换 成 整 型 。 在 将 非 整 型 数据 转换 成 整 型 时 ， 方 法 在 变量 前 使 用 (integer) 或 者 (int)， 转 换 规则 如 下 : 
浮 点 型 转换 成 整 型 。 小 数 点 后 的 数 将 被 舍弃 ， 如 果 浮 点 数 超出 整数 取 值 范 围 ， 那 么 将 无 法 得 到 有 效 的 
整 型 结果 ， 结 果 可 能 是 0 或 者 整 型 的 最 小 负数 。 
回 “布尔 型 转换 成 整 型 。true 值 将 转换 为 1，false 将 转换 为 0。 
回 ”字符 串 型 转换 为 整 型 。 将 会 对 字符 串 左 侧 的 第 1 位 进行 判断 。 如 果 第 1 位 是 数字 ， 则 从 第 1 位 开始 将 
读 取 到 的 数字 转换 成 整 型 ， 如 果 第 1 位 不 是 数字 ， 则 结果 为 0。 
(2) 转换 成 浮 点 型 。 方 法 在 变量 前 使 用 (floab， 转 换 规 则 如 下 : 
整 型 转换 为 浮 点 型 。 其 结果 不 会 发 生变 化 。 
回 “布尔 型 转换 为 浮 点 型 。 同 样 tue 值 将 转换 为 1，false 将 转换 为 0。 
加 ”字符 串 型 转换 为 浮 点 型 。 如 果 字 符 串 中 包含 小 数 点 “.” 或 科学 记 数 法 的 “e” 或 者 “E” 中 的 任何 一 个 
字符 ， 字 符 串 被 当 作 浮 点 型 处 理 ， 否 则 ， 被 视 为 整 型 。 
(3) 转换 成 字符 串 型 。 方 法 在 变量 前 使 用 (string)， 转 换 规则 如 下 : 
整 型 或 者 浮 点 型 转换 成 字符 串 型 。 转 换 结果 为 其 数值 。 
布尔 型 转换 为 字符 串 型 。true 值 将 转换 为 字符 串 “1”，false 将 转换 为 空 字符 串 。 
对 象 或 者 数组 型 转换 成 字符 串 型 。 那 么 转换 结果 为 字符 串 对 象 或 者 字符 串 数 组 。 
回 ”资源 型 转换 成 字符 串 型 。 转 换 结 果 为 一 个 类 似 “Resource id #” 的 字符 串 。 在 “#” 之 后 是 PHP 在 运行 
时 分 配给 该 资源 的 标识 代号 。 
(4) 转换 成 布尔 型 。 方 法 在 变量 前 使 用 (boolean) 或 者 (booD)。 因 为 布尔 型 只 包含 两 个 值 : tue 和 false， 所 
以 其 转换 规则 包括 两 个 方面 : 
方面 ， 转 换 结果 为 false 的 情况 。 
整 型 或 者 浮 点 型 数 0。 
空 字符 串 和 字符 串 “0”。 
没有 任何 元 素 的 空 数组 。 
没有 任何 元 素 的 对 象 。 
特殊 类 型 NULL。 
第 二 方面 ， 转 换 结果 为 true 的 情况 。 排 除 在 第 一 方面 说 明 的 情况 ， 其 他 转换 结果 都 为 tue。 
(5) 转换 成 数组 。 方 法 在 变量 前 使 用 (array)， 转 换 规则 是 : 将 非 数 组 型 转换 成 与 原 变量 数据 类 型 相同 的 数 
组 ， 数 组 中 只 有 一 个 元 素 。 
(6) 转换 成 对 象 。 方 法 在 变量 前 使 用 (objecb， 转 换 规 则 是 : 将 非 对 象 型 转换 成 一 个 新 的 对 象 ， 其 中 名 为 
scalar 的 成 员 变 量 将 包含 原 变量 的 值 。 


因 办 办 因 因 小 
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高 级 


趣味 指数 : 言语 疝 商 , 


实例 040 


图 实例 说 明 
大 楼 盖 得 好 不 好 主要 在 于 地 基 是 否 牢固 ， 变 量 就 是 PHP 编程 的 地 基 。 本 实例 介绍 变量 的 定义 与 应 用 ， 通 过 
echo 语句 实现 打印 “Hello World!!1” 的 小 程序 ， 运 行 结果 如 图 2.8 所 示 。 


Hello World!!! 


图 2.8 Hello World 程序 


图 关键 技术 

本 实例 的 关键 点 是 用 $ 符 号 定义 变量 ， 通 过 echo0 函 数 输出 变量 。PHP 中 的 变量 使 用 “$” 加 变量 名 来 表示 ， 
变量 名 是 区 分 大 小 写 的 。 使 用 变量 时 ， 只 需 对 变量 直接 赋值 即 可 。 变 量 赋值 ， 是 指 给 变量 一 个 具体 的 数据 值 ， 
对 于 字符 串 和 数字 类 型 的 变量 ， 可 以 通过 “=” 来 实现 ， 其 格式 如 下 : 

Sname = value; 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 定 义 字符 串 变 量 值 为 “Hello World!!!'”， 通 过 echo 语句 输出 定义 的 变量 ， 其 代 
人 码 如 下 : 


四 $str = "Hello World!!!"; /定义 变量 
echo $str: /输出 变量 
> 
(2) 将 该 文件 存储 于 \MR\02\040\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.8 所 示 。 
图 秘笈 心 法 


心 法 领悟 040: 变量 的 作用 域 。 
变量 有 其 自己 的 作用 域 ， 不 同 的 作用 域 有 不 同 的 作用 范围 ， 就 像 清华 大 学 学 生 的 学 生 证 不 能 在 北京 大 学 的 
图 书馆 借阅 图 书 一 样 。 
变量 按 其 作用 域 可 以 分 为 全 局 变量 、 局 部 变量 和 静态 变量 ， 变 量 作用 域 的 说 明 如 表 2.4 所 示 。 
表 2.4 变量 作用 域 的 说 明 


作 用 域 说 了 明 
即 被 定义 在 所 有 函数 以 外 的 变量 ， 其 作用 域 是 整个 PHP 文件 ， 但 是 在 用 户 自 定义 函数 内 部 是 不 可 用 的 。 
全 局 变量 《| 想 在 用 户 自 定义 函数 内 部 使 用 全 局 变量 , 要 使 用 global 关键 词 声明 , 或 者 通过 使 用 全 局 数组 $globals 进行 
访问 


局 部 变量 “| 即 在 函数 的 内 部 定义 的 变量 ， 这 些 变量 只 限于 在 函数 内 部 使 用 ， 不 能 在 函数 外 部 使 用 
能 够 在 函数 调用 结束 后 保留 变量 值 ， 当 再 次 回 到 其 作用 域 时 ， 又 可 以 继续 使 用 原来 的 值 。 而 一 般 变 量 在 
静态 变量 《| 函数 调用 结束 后 ， 其 存储 的 数据 值 将 被 清除 ， 所 占 的 内 存 空间 被 释放 。 使 用 静态 变量 时 ， 先 要 用 关键 字 


static 来 声明 变量 《需要 把 关键 字 static 放 在 要 定义 的 变量 之 前 ) 


< 注意 : 在 函数 的 内 部 定义 的 变量 ， 其 作用 域 是 所 在 函数 。 如 果 在 函数 外 赋值 ， 将 被 认为 是 完全 不 同 的 另 一 
个 变量 。 在 退出 声明 变量 的 函数 时 ， 该 变量 及 相应 的 值 就 会 被 撤销 。 
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趣味 指数 : 丰 丰 页 页 


实例 041 


图 实例 说 明 
PHP 编程 语言 中 预定 义 了 很 多 有 用 的 变量 ， 这 些 变量 往往 起 着 非常 重要 的 作用 。 本 实例 讲解 预定 义 变量 


$_ENV 的 相关 知识 ， 打 印 输出 系统 的 环境 变量 ， 运 行 结果 如 图 2.9 所 示 。 


Array => C:\Documents and Settings\All Users 
[CLASSPATH]S> ©;:\Program Files\StormlI\Codec;C: \Program Files\StormII 
[CommonProeranFiles] => C:\Program|Files\Conmon Files [CONPUTERNANE] = 
PC-201006101638 [ComSpec] => C:\WINDOWS\systein32\cmd. exe 

[FP NO_HOST SCHECE] => NO [NUMBER OF _PROCESSORS) => 1 [0S] => Windows_NT, 
[PATH] => C:\WINDOWS\system32;C:\WINDOWS;C:\WINDONS\System32\Wbem 
[PATHEXT] => .CON I EXE BAD,.CHD;. VBS,. VBE;. 8) .\JSE -WSFAWSH 
[PROCESSORARCHITECTURE] => x86 [PRDCESSOR_IDENTIFIER] => x86 Family 15 
Nodel 2 SteppingW9, GenuineIntel [PROCESSORILEVEL] => 15 
[PROCESSORSREVISION] => 0209 [ProgranFiles) =SC:\Program Files 
[SystenDrive] = C: [SystemRoot] => C:\WINDONS [TENP] 4 sh \WINDONS\TEAE, 
[THP] => CSMWINDONSMTENP [USERPROFILE] =C:ND6cuments 
Settings\LicalSefvice [windir] => C:\WINDOWS" [AP_PARENT J pio] => 292 ) 


图 2.9 预定 义 变量 的 应 用 


图 关键 技术 


PHP 提供 的 预定 义 变量 有 很 多 是 非常 实用 的 ， 通 过 这 些 预 定义 变量 可 以 获取 到 用 户 会 话 、 用 户 操作 系统 的 
环境 和 本 地 操作 系统 的 环境 等 信息 。 其 中 ，$_ENYV 是 执行 环境 提交 至 脚本 的 变量 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 通 过 print_r0 语 句 输出 系统 预定 义 变量 ， 其 代码 如 下 : 
print_($_ENV); /打印 系统 的 环境 变量 
2 将 该 文件 存储 于 \MR\02\041\ 文 件 夹 下 ， 命 名 为 ndex.php， 运 行 结果 如 图 2.9 所 示 。 
图 秘笈 心 法 


心 法 领悟 041: 重要 的 系统 预定 义 变量 。 
系统 的 预定 义 变量 是 比较 常用 的 技术 ， 读 者 必须 牢记 ， 尤 其 是 $ FILES、$_POST、$_GET 和 $_SESSION。 


实例 042 


力 实例 说 明 


变量 包括 预定 义 变 量 、 可 变 变量 等 ， 预 定义 变量 在 实例 041 中 已 经 做 了 简要 介绍 ， 本 实例 通过 可 变 变量 实 


现 输出 指定 字符 串 ， 运 行 结果 如 图 2.10 所 示 。 


1 Like PHP! 


图 2.10 使 用 可 变 变量 输出 
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图 关键 技术 

可 变 变量 是 一 种 独特 的 变量 ， 它 允许 动态 改变 一 个 变量 名 称 ， 其 工作 原理 是 该 变量 的 名 称 由 另外 一 个 变量 
的 值 来 确定 。 实 现 过 程 是 在 变量 前 多 加 一 个 “$” 符 号 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 一 个 字符 串 变量 ， 然 后 在 第 1 个 字符 串 变量 的 值 前 加 一 个 “$” 作 为 第 
2 个 变量 的 变量 名 ， 最 后 通过 echo 语句 输出 可 变 变 量 ， 其 代码 如 下 : 

<?php 


S$str name="str_ name 1"; /定义 变量 
$str name 1="ILike PHP!"; // 定 义 可 变 变量 
echo $$str name; /输出 可 变 变 量 
> 
(2) 将 该 文件 存储 于 \MR\02\042\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.10 所 示 。 
图 秘笈 心 法 


心 法 领悟 042: 可 变 变量 。 
可 变 变量 即 是 将 两 个 变量 的 值 使 用 一 个 变量 命名 进行 操作 , 但 是 要 注意 被 引用 的 变量 名 前 要 再 加 上 一 个 “$” 
符号 。 


实例 043 


图 实例 说 明 

在 定义 长 字符 串 变量 时 ， 字 符 串 本 身 往往 包含 一 些 特殊 字符 。 例 如 字符 串 本 身 包含 双 引号 〈“”) 。 这 时 
就 需要 使 用 转 义 字符 对 特殊 字符 进行 转 义 。 本 实例 通过 转 义 字符 “\” 转 义 经 特殊 字符 双 引号 (“”) 包含 的 字 
符 串 ， 运 行 结果 如 图 2.11 所 示 。 


“PHP 是 一 门 WHeb 开 发 最 火 的 编程 语言 
图 2.11 使 用 转 义 字符 输出 特殊 字符 


图 关键 技术 


本 实例 的 关键 点 是 转 义 字符 “\” 的 使 用 ， 它 除了 可 以 做 转 义 字符 外 ， 还 有 一 些 其 他 功能 ， 即 可 以 将 一 些 不 
可 打印 的 字符 显示 出 来 ， 例 如 va、\b、\e、 mm、 和 Mt 等 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 通 过 echo 语句 输出 经 转 义 字符 转 义 的 特殊 字符 ， 其 代码 如 下 : 
echo "\"PHP 是 一 门 Web 开发 最 火 的 编程 语言 "; /输出 转 义 字符 转 义 的 字符 串 


> 
(2) 将 该 文件 存储 于 \MR\02\043\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.11 所 示 。 
图 秘笈 心 法 


心 法 领情 043: 转 义 字符 的 功能 。 
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转 义 字符 的 功能 只 有 一 个 ， 就 是 将 特殊 字符 转 义 成 普通 字符 。 


图 实例 说 明 


常量 是 PHP 编程 基础 的 重要 组 成 部 分 ， 其 作用 是 定义 一 个 不 会 改变 的 值 。 本 实例 通过 计算 圆 的 面积 向 用 户 
说 明 常 量 是 如 何 定义 和 使 用 的 ， 运 行 结 果 如 图 2.12 所 示 。 


半径 为 0 个 单位 的 圆 的 面积 31 本 15926 
图 2.12 使 用 常量 指定 PI 的 值 计算 圆 的 面积 


力 关键 技术 


PHP 中 通常 使 用 define0 函 数 来 定义 常量 ; 使 用 constant0 函 数 动态 获取 常量 值 ; 使 用 definedO 函 数 判断 一 个 
常量 是 否 已 经 定义 ， 使 用 get_defined_constants0 函 数 获取 所 有 当前 已 经 定义 的 常量 。 其 中 ，define() 函 数 的 语法 
如 下 所 示 : 

define0: 定义 常量 。 

bool define ( string name, mixed value [, bool case_insensitive] ): 

参数 说 明 : 

string name: 必 选 参数 ， 常 量 名 称 ， 即 标识 符 。 

mixed value: 必 选 参数 ， 常 量 的 值 。 

bool case_insensitive: 可 选 参数 ， 指 定 大 小 写 是 否 敏感 。 设 定 为 tue， 表 示 不 敏感 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 通过 define0 函 数 定义 常量 ， 将 数值 “3.1415926” 定 义 为 常量 名 为 PI 的 常 
量 ， 然 后 定义 数值 型 变量 ， 将 圆 的 半径 设 定 为 10 个 单位 。 最 后 通过 echo 语句 输出 圆 面积 ， 其 代码 如 下 : 


define("PI".3.1415926): /定义 常量 
Sr=10; /定义 圆 半径 
echo "半径 为 10 个 单位 的 圆 的 面积 "PIY(Sr*SnD: /定义 圆 面积 
> 
(2) 将 该 文件 存储 于 \MR\02\044\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.12 所 示 。 
图 秘笈 心 法 


心 法 领悟 044: 使 用 define0 定 义 常量 的 注意 事项 。 
使 用 define0 定 义 的 常量 一 旦 定义 就 不 能 改变 或 者 取消 。 
22 运 算 符 


运算 符 是 用 来 对 变量 、 常 量 或 数据 进行 计算 的 符号 ， 是 对 一 个 值 或 一 组 值 执 行 一 个 指定 的 操作 。PHP 的 运 
算 符 包括 字符 串 运 算 符 、 算 术 运 算 符 、 赋 值 运算 符 、 递 增 或 递减 运算 符 、 位 运算 符 、 逻 辑 运算 符 、 比 较 运 算 符 
和 条 件 运 算 符 。 
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趣味 指数 : 坪 评 评 窗 


图 实例 说 明 


运算 符 是 表达 式 的 组 成 部 分 ， 没 有 运算 符 的 表达 式 是 不 存在 的 。 本 实例 通过 使 用 算术 运算 符 设置 数字 的 加 
密 /解密 算法 ， 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 


ps [确定 ] 数字 D 令 中 1081 
Pt 1084 二 15926 解 达 D 令 “108t 
图 2.13 口令 加 密 图 2.14 口令 解密 


图 关键 技术 

本 实例 的 关键 点 是 将 数字 进行 算术 运算 进而 得 到 加 密 / 解 密 结 果 。 算 术 运 算 (Arithmetic Operators) 符号 是 
处 理 四 则 运算 的 符号 ， 在 数字 处 理 中 应 用 得 最 多 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 名 为 PI 的 常量 。 然 后 编写 自 定义 
函数 ， 在 自 定义 函数 方法 体内 定义 加 密 或 解密 算法 。 最 后 ， 当 表单 提交 后 ， 调 用 对 应 的 加 密 或 解密 算法 ， 并 输 
出 结果 ， 其 代码 如 下 : 

<2php 

echo "<form action=" method='post>"; /输出 表单 


echo "数字 口令 :<input name='text type=text>"; 
echo "<input type='submit’ name='sub' value 一 确定 >": 


echo “</form>"; 


define("PI".3.1415926): /定义 常量 
function Encrypt($str){ // 自 定义 加 密 算法 
Teturn $str = $str + PI; // 将 口令 与 常量 相 加 
1 
function Decrypt($st){ /1/ 自 定义 解密 算法 
Teturn $str = $str - PI; /| 将 加 密 后 口令 与 常量 相 减 
| 
这 $_POST[sub]){ /通过 post 方式 传 参 
echo "加 密 口 令 &nbsp:&nbsp:".Encrypt(S_POST[text)."<br>" /取得 加 密 后 的 结果 
$_SESSION[pwd] = Encrypt($_POST[text]): // 保 存在 session 中 
> 
<a href-'index.php?pwd-1> 解 密 口令 </a> // 超 链接 
<?php 
} 
iflisset($_GET[pwd])){ /天 断 地 址 栏 中 是 否 存 在 pwd 
echo "解密 口令 &nbsp:&nbsp:"Decrypt($_SESSION[pwd]): /口令 解密 


} 
> 
(2) 将 该 文件 存储 于 \MR\02\045\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 
图 秘笈 心 法 


心 法 领悟 045: 运算 符 的 优先 级 。 
本 实例 并 没有 联合 应 用 多 种 运算 符 ， 当 联合 应 用 时 要 注意 运算 符 优先 级 的 问题 。 所 谓 的 优先 级 就 是 先进 行 
哪 种 运算 符 的 运算 再 进行 哪 种 运算 符 的 运算 。 为 了 方便 用 户 ， 笔 者 将 运算 符 的 优先 级 进行 归 类 ， 如 表 2.5 所 示 。 
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表 2.5 运算 符 的 优先 级 


优先 级 别 运 算 符 
1 Or, and, xor 
2 三 ，+=， 一 二 ，*=，/=， 二 ，%= 
3 |, && 
4 |, ^ 
委 &，. 
6 ++，--〈 递 增 或 递减 运算 符 ) 
村 /,*,% 
3 er 
9 = 
10 +， 一 ( 正 、 负 号 运算 符 )，!，~ 
11 
12 
13 ? 
14 二 > 
15 a 


实例 046 


图 实例 说 明 


在 一 些 程序 中 ， 经 常 需要 将 两 个 时 间 进 行 比较 ， 但 是 由 于 时 间 是 由 年 、 月 、 日 、 时 、 分 、 秒 组 成 的 ， 比 较 
起 来 很 不 方便 ， 这 时 可 以 把 时 间 转 换 成 时 间 戳 来 进行 比较 。 本 实例 通过 date0、strtotimeO 和 ceil0 函 数 实现 比较 
两 个 时 间 戳 的 大 小 ， 运 行 结果 如 图 2.15 所 示 。 


1274924802 输出 日 期 2010-05-27 09:46:42 


1272988800 输出 日 期 2010-05-05 00:00:00 


距 2010 年 5 月 5 号 书 过 去 3 天 


2.15 比较 两 个 时 间 戳 的 大 小 


图 关键 技术 


本 实例 主要 是 通过 利用 strtotimeO 函 数 将 时 间 转 换 为 UNIX 时 间 戳 ， 再 进行 相关 取 整 运算 而 实现 的 ， 其 中 涉 
及 到 的 相关 函数 的 语法 如 下 : 
(1) strtotimeO 函 数 。 该 函数 预期 接受 一 个 包含 英文 日 期 格式 的 字符 串 , 并 尝试 将 其 解析 为 UNIX 时 间 惟 : 
int strtotime( string time [. int now]): 
strtotimeO 函 数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如果 参数 time 的 格 
式 是 相对 时 间 ， 其 对 应 的 时 间 由 参数 now 来 提供 ， 若 没有 提供 参数 now， 则 其 对 应 的 时 间 为 当前 时 间 。 如 果 解 
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析 失 败 ， 则 返回 false。 在 PHP5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 
(2) ceil0 函 数 。 该 函数 返回 不 小 于 value 的 下 一 个 整数 : 
float ceil ( float value); 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 对 PHP 语言 中 的 时 区 进行 设置 ， 将 时 区 更 改 为 中 国 上 海 时 区 。 然 后 ， 通 过 
strtotime() 函 数 获取 当前 时 间 的 UNIX 时 间 戳 ， 并 与 指定 的 时 间 戳 进行 算术 运算 。 最 后 ， 将 时 间 戳 运算 结果 转换 
为 天 数 ， 并 通过 ceil0 函 数 进行 取 整 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 
<?php 


王 


date_default_timezone_set("Asia/ShangHai"): Vtech ladar md 间 
$a = strtotime("now"); /取得 当前 时 间 

$b = strtotime("05 May 2010"); /1/ 取 得 2010 年 5 5 号 的 时 间 截 
echo $a."\n"; 

echo "输出 日 期 "date("Y-m-d Hii:s",$a)."<br><br>"; /取得 以 Sa 为 时 间 点 的 时 间 

echo $b."\n"; 

echo "输出 日 期 ".date("Y-m-d H:i:s",$b)."<br><br>"; /取得 以 Sb 为 时 间 点 的 时 间 

$c = ceil(($a - $b)/(3600*24)); 1/ 计算 相差 天 数 


echo " 距 2010 年 5 月 5 号 已 过 去 ".$c." 天 "; 
(2) 将 该 文件 存储 于 \MR\02\046 文件 夹 下 ， 命 名 为 mndex.php。 运 行 结果 如 图 2.15 所 示 。 
图 秘笈 心 法 


心 法 领悟 046: 时 间 戳 的 相关 说 明 。 

有 效 的 时 间 戳 的 范围 通常 从 Fri, 13 Dec 1901 20:45:54 GMT 到 Tue, 19 Jan 2038 03:14:07 GMT (对 应 于 32 位 
有 符号 整数 的 最 小 值 和 最 大 值 ) 。 不 是 所 有 的 平台 都 支持 负 的 时 间 戳 ,因此 日 期 范围 就 被 限制 为 不 能 早 于 UNIX 
纪元 。 这 意味 着 在 1970 年 1 月 1 日 之 前 的 日 期 将 不 能 用 在 Windows、 一 些 Linux 版 本 以 及 几 个 其 他 的 操作 系 
统 中 。 


< 注意 :在 UNIX 系统 中 ， 日 期 与 时 间 表 示 为 自 1970 年 1 月 1 日 零点 起 到 当前 时 刻 的 秒 数 ， 这 种 时 间 称 为 
UNIX 时 间 稚 ,用 32 位 二 进 制 表 示 。 其 中 ，1970 年 1 月 1 日 零点 称 为 UNIX 世纪 元 。UNIX 时 间 稚 
提供 了 一 种 统一 、 简 洁 的 时 间 表 示 方式 ， 在 不 同 的 操作 系统 中 均 受 到 支持 ， 同 一 时 间 在 UNIX 和 
Windows 中 均 以 相同 的 UNIX 时 间 截 表示， 所 以 不 需要 在 不 同 的 系统 中 进行 转换 。 同 时 ，UNIX 时 
间 截 是 一 个 时 间 差 ， 与 时 区 没有 关系 ， 无 论 当前 PHP 中 使 用 的 是 何 种 时 区 ， 其 UNIX 时 间 鹤 是 唯 
一 的 。 


数字 的 奇偶 性 高 级 


实例 047 


图 实例 说 明 


条 件 运 算 符 是 用 于 执行 或 真 或 假 运算 的 。 本 实例 演示 如 何 用 三 元 运算 符 判断 数字 的 奇偶 性 ， 运 行 结 果 如 
图 2.16 所 示 。 


0 是 偶数 1 是 奇数 2 是 偶数 3 是 奇数 
5 是 奇数 6 是 偶数 7 是 奇数 8 是 偶数 9 是 奇数 


2.16 用 三 元 运算 符 判断 奇数 偶数 


第 2 章 PHP 基础 


图 关键 技术 


本 实例 使 用 三 元 运算 符 判断 数字 的 奇偶 性 ， 并 且 在 判断 数字 奇偶 性 时 使 用 了 求 余 运算 符 。 当 期 望 数字 与 数 
字 2 做 除法 运算 时 ， 如 果 存 在 余数 即 不 能 被 2 整除 ， 为 奇数 ， 否 则 为 偶数 。 三 元 运算 符 的 语法 如 下 所 示 : 

(expD ? {statement1;} : {statement2;} 

三 元 运算 符 与 让 ..else... 函 数 实现 的 功能 完全 相同 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 ， 通 过 for 循环 语句 循环 输出 0-9 的 10 个 数字 。 然 后 ， 将 得 到 的 10 个 数字 
分 别 与 2 做 求 余 运算 并 将 运算 结果 作为 三 元 运算 的 条 件 进行 判断 。 最 后 ， 将 判断 的 结果 利用 echo0 语 句 输出 ， 
其 代码 如 下 : 


<?php 
/做 小 于 10 的 循环 
for($a= 0;$a < 10;$at+){ 
/用 三 元 运算 输出 ， 如 果 没 有 余数 则 是 偶数 ， 否 则 为 奇数 
echo $a%2 一 0? $a." 是 偶数 "."\n" : $a." 是 奇数 "."\n"; 
} 


> 


2) 将 该 文件 存储 于 \MR\02\047\ 文 件 夹 中 ， 命 名 为 mdex.php。 运 行 结 果 如 图 2.16 所 示 。 
秘笈 心 法 


心 法 领悟 047: 用 让..else... 语 句 实现 实例 。 
三 元 运算 等 同 于 让 ...else... 语 句 ， 下 面 就 通过 让 .else... 语 句 实现 本 实例 ， 其 语法 如 下 : 


<?php 

/做 小 于 10 的 循环 

for($a = 0:Sa < 10:$a++){f 

/用 证 ,.else… 语 句 实现 
$b=0; 
if($a% 2 —0){ 

// 设 定 条 件 ， 让 $a 与 2 做 求 余 运算 

echo "$a".' 是 偶数 '; 

Jelse{ 


echo "$a".,' 是 奇数 


: 
高 级 | 
趣味 指数 : 机 机 宙 


图 实例 说 明 


逻辑 运算 符 往往 作为 让 等 语句 的 条 件 出 现 。 逻 辑 运 算 符 有 很 多 种 而 且 功能 各 不 相同 。 本 实例 介绍 逻辑 运算 
符 的 语法 等 相关 知识 , 并 通过 逻辑 运算 符 来 演示 用 户 是 否 具有 后 台 管 理 权限 , 运行 结果 如 图 2.17 和 图 2.18 所 示 。 


图 2.17 具有 后 台 管 理 权限 图 2.18 不 具有 后 台 管 理 权限 
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图 关键 技术 


本 实例 主要 是 通过 逻辑 运算 符 && (逻辑 与 ) 将 从 表单 中 利用 POST 方法 取得 的 由 文本 框 输入 的 用 户 名 和 密 
但 联系 起 来 。 用 户 名 和 密码 必须 同时 为 真 ， 寺 语句 的 结果 才 会 为 真 ， 反 之 为 假 。 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 <form> 表 单 ， 将 表单 中 的 method 方法 定义 为 POST。 然 后 ， 当 单 击 
按钮 时 ， 将 POST 方法 接收 的 用 户 名 和 密码 进行 逻辑 与 运算 。 当 让 语句 的 结果 为 Tme 时 ， 输 出 “您 具有 管理 员 
WO 的 提示 ， 否 则 输出 “您 非 权 限 用 户 ” 的 提示 ， 其 代码 如 下 : 

echo "<form action="method='post >"; /输出 表单 

echo "用 户 名 : <input type='text name=text><br>"; 


echo " 密 &nbsp;&nbsp; 码 : <input type= password name=pwd>"; 
echo "<input type='submit’ name='sub' value= 确 定 >"; 


echo “</form>"; 
if($_POST[sub) { /通过 post 方式 提交 
这 $_POST[text] 一 "mr" && $_POST[pwd] 一 "mrsoft"){ /验证 用 户 名 密码 
echo "<script>alert( 您 具有 管理 员 权限 ?;</script>": /符合 条 件 输出 提示 
jelsef 
echo "<script>alert( 您 非 权限 用 户 "):</script>"; // 不 符合 条 件 输出 提示 


} 
| 


3 将 该 文件 存储 于 \MR\02\048\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.17 和 图 2.18 所 示 。 
必 答 心 法 


心 法 领悟 048: 使 用 优先 级 的 小 技巧 。 
如 果 在 涉及 到 运算 符 的 优先 级 时 不 想 总 查找 优先 级 表 而 本 身 又 记忆 不 清 的 话 ， 建 议 使 用 小 括号 把 想 要 先 运 
算 的 表达 式 括 起 来 ， 这 样 问题 就 迎刃而解 了 。 


高 级 
站 本 拉 归 有 有 页 


力 实例 说 明 


在 应 用 字符 串 时 往往 需要 将 两 个 字符 串 进行 连接 ， 这 时 候 可 以 使 用 字符 串 运 算 符 。 本 实例 使 用 字符 串 运算 
符 打印 随机 组 合生 日 祝福 语 ， 运 行 结果 如 图 2.19 所 示 。 


生 目 快乐 祝 你 万 事 如 意 


图 2.19 ”打印 随机 组 合生 日 祝福 语 


转 关键 技术 


字符 串 可 以 用 “.”( 点 ) 字符 串 连接 符 连 接 ， 该 连接 符 可 以 把 两 个 或 两 个 以 上 字符 串 连接 成 一 个 新 的 字符 
串 。 字 符 串 的 连接 有 两 种 形式 ， 第 1 种 是 连接 运算 符 “.”; 第 2 种 是 连接 赋值 运算 符 “=”。 在 实际 的 程序 开 
发 中 ， 这 两 种 连接 方式 都 非常 常用 


图 设计 过 程 


创建 index.php 文件 ， 首 先 ， 定 义 两 个 数组 ， 将 字符 串 信息 保存 在 数组 之 中 。 然 后 ， 利 用 rand 函数 随机 取 
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得 数组 中 的 两 条 信息 并 保存 在 变量 中 。 最 后 ， 通 过 echo 语句 输出 用 连接 运算 符 连 接 的 变量 ， 其 代码 如 下 : 
php 


$arr = array(" 生 日 快乐 "." 今 天 是 你 的 出 生日 "," 同 学 们 为 你 许愿 "); /定义 数组 
Sarray = array(" 祝 你 万 事 如 意 "" 祝 你 生日 快乐 "" 视 你 福 如 东海 长 流水 寿 比 南山 不 老 松 "); /定义 数组 
Srand = rand(0.2); /定义 随机 数 
echo $arr[Srand].Sarray[Srand]: /输出 字符 串 
> 
国 秘笈 心 法 


心 法 领悟 049: “+” 号 的 相关 说 明 。 
使 用 过 C 或 JAVA 的 读者 应 该 注意 ， 这 里 的 “ 


， 只 做 算术 运算 符 使 用 ， 而 不 能 做 字符 串 运算 符 。 


趣味 指数 : 合 俩 耸 侠 | 


图 实例 说 明 


在 PHP 语言 中 ， 为 了 提升 编程 效率 设置 了 一 些 自 增 自 减 运算 符 ， 这 些 运算 符 在 循环 语句 中 得 到 广泛 应 用 。 
本 实例 简要 介绍 了 自 增 自 减 运算 符 , 并 通过 自 增 自 减 运算 符 修饰 的 变量 来 演示 其 应 用 , 运行 结果 如 图 2.20 所 示 。 


打印 2000~2020 年 之 间 的 所 有 赣 年 


2000 2004 2003 B2012 2016@2020| 
图 2.20 打印 2000~2020 年 的 所 有 闪 年 


图 关键 技术 

递增 或 递 成 运算 符 有 两 种 使 用 方法 ， 一 种 是 先 将 变量 增加 或 减少 1 后 再 将 值 赋 给 原 变量 ， 称 为 前 置 递增 或 
递 碱 运算 符 ( 也 称 前 置 自 增 自 减 运算 符 ): 另 一 种 是 将 运算 符 放 在 变量 后 面 ， 即 先 返 回 变 基 的 当前 值 ， 然 后 变 
量 的 当前 值 增加 或 减少 1， 称 为 后 置 递增 或 递减 运算 符 〈 也 称 后 置 自 增 自 减 运 算 符 )。 本 实例 将 递增 递减 运算 
符 应 用 到 for 循环 的 变量 之 中 ， 利 用 变量 的 变化 完成 期 望 次 数 的 循环 。 
图 设计 过 程 

创建 index.php 文件 ， 首 先 ， 利 用 for 循环 定义 循环 变量 ， 将 变量 的 初始 值 设置 为 2000， 最 大 值 小 于 2020， 
并 且 要 求 变量 做 自 增 运算 。 然 后 ， 设 置 循环 变量 与 4 做 求 余 运算 。 最 后 , 把 符合 条 件 的 数值 通过 echo 语句 输出 ， 


代码 如 下 : 
<?php 
这 $_POST[sub]){ /通过 post 接收 参数 
for($a = 2000;$a <= 2020;$att){ /通过 循环 定义 循环 变量 
isa%4 一 0)f{ /| 将 循环 变量 与 4 做 求 余 运算 
echo $a "Snbsp:S&nbsp: /输出 循环 变量 
} 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 050: 自 增 自 减 运算 符 。 
自 增 自 减 运算 符 在 PHP 循环 结构 中 ， 特 别 是 for 循环 结构 中 有 着 非常 重要 的 地 位 。 至 于 自 增 自 减 运算 符 前 
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置 和 后 置 的 区 别 ， 请 详 见 实例 051 一 一 前 置 运算 符 和 后 置 运算 符 的 区 别 。 


图 实例 说 明 


前 置 运算 符 与 后 置 运算 符 的 应 用 方向 与 实例 050 相同 ， 大 多 用 在 循环 语句 中 。 本 实例 应 用 自 增 自 减 运算 符 
来 修饰 变量 ， 通 过 显示 结果 来 说 明 前 置 运 算 符 与 后 置 运 算 符 的 区 别 ， 运 行 结果 如 图 2.21 所 示 。 


一- 后 轩 加 证 生 -一 


3 -后 
109876543210 


图 2.21 前 置 运 算 符 与 后 置 运算 符 的 区 别 


图 关键 技术 


本 实例 的 关键 点 是 自 增 自 减 运算 符 的 灵活 运用 ， 相 关 说 明 详 见 实例 050。 在 使 用 前 置 减 运算 符 时 ， 要 注意 
给 定 的 初始 值 ， 否 则 会 出 现 本 例 的 问题 ， 即 前 置 减 运算 输出 负数 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 通 过 for 循环 语句 定义 循环 变量 ， 然 后 ， 通 过 echo 语句 输出 循环 变量 ， 
其 代码 如 下 : 
<?php 
$a=0; // 自 定义 变量 并 给 定 初始 值 
echo ". 后 秆 加 运算 ---------<br>"; 
for($b = 0:Sb <= 10:Sb+H){ /使 用 for 循环 语句 
echo $at+.""; 1/ 使 用 后 置 运算 符 
} 
echo "<br>---------- 前 秆 加 运算 --------<br>"; 
$d=0; 
for(sb =0;Sb <= 10; Spt 
echo ++$d." " // 使 用 后 置 运算 符 


} 
echo "<br>---------- 前 置 减 运算 -------<br>"; 
$f=10; 
for($b = 10: 省 于 03Sb- 
echo --$: // 使 用 前 置 运算 符 
} 
echo "<br>--------- 后 置 减 运算 ---------<br>"; 
S$g=10; 
fornsb= 10:Sb >—0; Ot 
echo Sg--." // 使 用 后 置 运算 符 
} 


> 

(2) 将 该 文件 存储 于 \MR\02\051\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.21 所 示 。 
图 秘笈 心 法 

心 法 领悟 051: 前 置 运算 符 。 
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前 置 运算 符 是 在 程序 第 一 次 运行 时 就 进行 自 增 或 自 减 运算 ， 而 后 置 运算 符 是 在 程序 运行 完 一 次 之 后 再 进行 
自 增 或 自 减 运算 。 


实例 052 


力 实例 说 明 
位 运算 符 也 是 PHP 运算 符 中 不 可 或 缺 的 一 种 .本 实例 通过 位 运算 符 实现 对 数字 进行 加 密 , 运行 结果 如 图 2.22 
和 图 2.23 所 示 。 
数字 口令 中 111 [确定 ] i 本 
Et FS 解 可 0 及 111 
图 2.22 ”使 用 位 运算 符 对 数字 进行 加 密 图 2.23 ”使 用 位 运算 符 对 数字 进行 解密 
图 关键 技术 


i 位 对 齐 后 进行 运算 ，PHP 中 的 位 运算 符 如 表 2.6 所 示 。 本 实例 中 ， 利 用 
量 做 指定 的 位 运算 ， 并 返回 计算 结果 ， 从 而 将 文本 框 信息 进行 加 密 或 解 


位 运算 符 是 指 对 二 进 制 位 从 低 到 高 
自 定义 函数 ， 将 文本 框 信息 与 定义 的 常 
密 处 理 。 


表 2.6 位 运算 符 


举例 
3$m&y$n 
$ml$n 
$m^$n 
$m~$n 


$m<<$n 


$m>>$n 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 <form> 表 单 并 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 PI。 然 后 ， 
定义 自 定义 函数 ， 在 函数 体内 部 ， 将 文本 框 信息 与 常量 PI 做 移 位 运算 并 返回 结果 。 最 后 ， 通 过 提交 数据 和 单 击 
按钮 实现 输出 加 密 、 解 密 算 法 的 结果 ， 其 代码 如 下 : 
<?php /定义 表单 
echo "<form action=" method='post>"; 
echo "数字 口令 : <input name='text type=text>"; 


echo "<input type=submit name='sub' value= 确 定 >"; 
echo “</form>": 


define("PI".3.1415926): /定义 常量 

function Encrypt($str) { // 自 定义 加 密 算法 
Teturn $str = $str << PI; 

fonction Decrypt($st){ /1/ 自 定义 解密 算法 
Teturn $str = $str >> PI; 

} 

这 $_POST[sub]){ /通过 post 方式 传 参 
echo "加 密 口令 &nbsp;&nbsp:".Encrypt($_POST[text])."<br>": /只 出 口令 
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$_SESSION[pwd] = Encrypt($_ POST[text]): /将 口令 保存 在 session 中 
> 
<a href='index.php?pwd=1> 解 密 口令 </a> /起 链接 
<?php 
} 
iflisset($_GET[pwd])){ /判断 地 址 栏 是 否 存在 此 参数 
echo "解密 口令 &nbsp:&nbsp:".Decrypt($_SESSION[pwd]); /输出 解密 结果 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\052\ 文 件 夹 下 ， 命 名 为 mdex.php。 运 行 结果 如 图 2.22 和 图 2.23 所 示 。 
图 秘笈 心 法 


心 法 领悟 052: 位 运算 符 的 相关 说 明 。 
位 运算 符 允 许 对 整 型 数据 中 指定 的 位 进行 置 位 。 如 果 左 右 参数 都 是 字符 串 ， 则 位 运算 符 将 操作 字符 的 
ASCII 值 。 


23 包含 语句 


引用 外 部 文件 可 以 减少 代码 的 重用 性 ， 是 PHP 编程 的 重要 技巧 。PHP 提供 了 4 个 非常 简单 有 用 的 语句 ， 它 
们 允许 重新 使 用 任何 类 型 的 代码 。 使 用 任意 一 个 语句 均 可 以 将 一 个 文件 载 入 PHP 脚本 中 ， 为 网 站 创建 统一 风格 
的 页 面 ， 从 而 更 加 轻松 地 编写 和 维护 代码 。 


图 实例 说 明 


当 需 要 在 文件 外 部 引入 新 文件 时 就 要 借助 include0 或 require0 等 包含 语句 。 本 实例 通过 require0 包 含 语句 实 
现代 码 重用 ， 运 行 结果 如 图 2.24 所 示 。 


一 天 , 老 杨 开 着 自己 的 奥拓 小 汽车 在 公路 上 行 强 ， 不 一 会 后 面 来 了 辆 大 奔 ,+ 太 寺 司机 冲 
着 志 杨 说 : “哥们 , 开 过 类 和 卉 吗 9 7 樵 后 用 一 下 开 走 了 ， 老 杨 很 生气 \ 心 填 开 大 洗 就 牛 
加 网 种 二 bn 大 油门 “ 赶 上 了 大 奔 忆 太 千 司机 又 问 关 】 守 们 ， 开 过 大 奔 吗 ”然后 噶 的 一 下 开 
志 了 . 老 杨 再 也 措 不 上 了 。 只 能 生 着 问 气 的 向 前 开 着 ,过 了 一 会 ， 路 边 短 着 一 辆 大 奔 ,司机 
被 压 在 车 下 ， 看 见 志 杨 开车 过 来 ， 就 苘 着 器 腔 说 : “老大 ，。。 你 开 过 大 奔 吗 。。。 阐 车 
在 哪 品 ? 


2.24 ”提高 代码 重用 率 


图 关键 技术 


本 实例 通过 require0 语 句 包含 并 运行 指定 文件 。PHP 文件 被 执行 之 前 ，PHP 解析 器 会 用 被 引用 的 文件 的 全 
部 内 容 替换 require0 语 句 ， 然 后 与 require0 语 句 之 外 的 其 他 语句 组 成 新 的 PHP 文件 。 最 后 再 按 新 的 PHP 文件 执 
行程 序 代码 ， 其 语法 如 下 : 

void require(string filename): 
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参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 


图 设计 过 程 
(1) 创建 ne php 文件 ， 建 立 两 个 字符 串 表达 式 ， 代 码 如 下 : 


<?php 

S$str1 =" 大 连 是 一 个 美丽 的 地 方 ， 它 三 面 环 海 ， /声明 两 个 字符 串 变 量 

背 依 大 山 ， 就 像 一 个 乘风破浪 的 水 手 ， 

就 算 再 大 的 风浪 ， 也 依然 昂首 挺 胸 不 届 不 找 "; 

S$str2= "一 天 ， 老 杨 开 着 自己 的 奥拓 小 汽车 在 公路 上 行驶 ， 不 一 会 后 面 来 了 一 辆 大 奔 

。 大 奔 司 机 冲 着 老 杨 说 : “哥们 ， 开 过 大 奔 吗 ? ”， 然 后 咱 一 下 开 走 了 ， 老 杨 很 生气 ， 心 想 

开 大 奔 就 牛 吗 ， 然 后 加 大 油门 ， 赶 上 了 大 奔 ， 大 奔 司 机 又 问 : “哥们 ， 开 过 大 奔 吗 ”然后 咱 地 一 下 

开 走 了 ， 老 杨 再 也 撞 不 上 了 。 只 能 生 着 闷气 地 向 前 开 着 ， 过 了 一 会 ， 路 边 翻 着 一 辆 大 奔 ， 司 机 被 压 在 车 下 , 
看 见 老 杨 开车 过 来 ， 就 带 着 哭 腔 说 : “老大 。。。 你 开 过 大 奔 吗 。。。 箱 车 在 哪 啊 ? ”"; 

> 


(2) 创建 index.php 文件 ， 通 过 require0 语 句 包含 文件 ncphp， 代 码 如 下 : 
<?php 


ire("inc.php"); 
switch($_GET[link]){ /接收 地 址 栏 的 值 
case "我 的 家 乡 "; /如 果 值 等 于 我 的 家 乡 
echo $strl; /输出 字符 串 1 
breaks /停止 执行 语句 
case "幽默 笑话 ": // 如 果 值 等 于 曲 默 笑话 
echo $str2; /输出 字符 串 2 
break; /停止 执行 语句 
加 》 
图 秘笈 心 法 


心 法 领悟 053: 使 用 require0 语 句 的 注意 事项 。 
因为 使 用 require0 语 句 相当 于 将 另 一 个 源 文件 的 内 容 完 全 复制 到 本 文件 中 ， 所 以 一 般 将 该 语句 放 在 源 文件 
的 起 始 位 置 ， 用 于 引用 需要 使 用 的 公共 函数 和 公共 类 文件 等 。 


Ey 
沪 


趣味 指数 : 商 催 页 南 


力 实例 说 明 


-个 程序 可 能 要 与 数据 库 多 次 交互 ， 所 以 数据 库 连 接 信息 要 单独 保存 在 某 一 文件 中 ， 这 也 是 代码 重用 的 一 
种 体现 。 本 实例 通过 include 0 语句 包含 数据 库 文件 ， 运 行 结果 如 图 2.25 所 示 。 


编号 ，1 姓名 : 杨 明 
2 姓名 :_ 守 凯 华 
3 姓名 二 杨 明 

编号 :4 ”姓名 汪 凯 华 
5 姓名 刘 中 华 

编号 ， 6 姓名: 刘 中 华 


2.25 包含 数据 库 连接 文件 


图 关键 技术 


include0 语 句 与 requireO 语 句 在 作用 上 是 完全 相同 的 ， 但 是 使 用 includeO 语 句 引 用 外 部 文件 时 ， 只 有 代码 执 
行 到 该 语句 时 才 将 外 部 文件 引用 进来 并 读 取 文件 的 内 容 ， 当 所 引用 的 外 部 文件 发 生 错误 时 ， 系 统 只 给 出 一 个 警 
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告 ， 整 个 PHP 文件 则 继续 向 下 执行 。include0 语 句 的 语法 如 下 : 
void include(string filename); 
参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 通 过 include(O 语 句 包 含 数据 库 文件 ， 并 执行 查询 操作 ， 输 出 结果 ， 其 代码 
如 下 : 


<?php 
include (vinc.php"); // 包 含 数据 库 连 接 文件 
$sql = "select * from tb_include"; //sql 语 句 
Srs = mysql_query($sq)); /执行 查询 操作 
while($rst = mysql_fetch_array($rs){ /将 查询 结果 循环 输出 
echo 咏 号 : "Srst[o].&nbsp:&nbsp: 姓 名 : "Srst[1]."<br>": 

} 
> 

(2) 创建 数据 库 连 接 文件 inc.php， 其 代码 如 下 : 
<?php 
$conn = mysql_connect("localhost","root","111"); // 连 接 MYSQL 
mysql_select_db("db_database02",$conn); // 连 接 数 据 库 
mysql_query("SET NAMES GBK"); // 设 置 编码 格式 
> 
岂 笈 心 法 


心 法 领悟 054: 使 用 include0 语 句 的 注意 事项 。 
include 0 语句 当 包 含 一 个 不 存在 的 文 


; Ee 
图 实例 说 明 


在 设计 网 站 的 过 程 中 往往 都 是 先 用 table 或 div 标签 将 整个 网 站 进行 布局 , 然后 通过 include_once0 等 语句 将 
各 部 分 内 容 包含 进来 。 本 实例 介绍 使 用 include_once0O 语 句 包含 网 站 头 文件 ， 运 行 结果 如 图 2.26 所 示 。 


心 严 强 本 加 着 
是 当 责 芝 过 党 区 


图 2.26 包含 网 站 头 文件 


图 关键 技术 


PHP 程序 开发 中 ， 在 使 用 include_ onceO 语 名 时， 应 该 明确 其 与 include0 语 句 的 区 别 。include_once0 语 句 会 
在 导入 文件 前 检测 该 文件 是 否 在 该 页 面 的 其 他 部 分 被 引用 过 ， 如 果 有 ， 则 不 会 重复 引用 该 文件 ， 即 程序 只 引用 
-次 。 例 如 ， 要 导入 的 文件 中 存在 一 些 自 定义 函数 ， 如 果 在 同一 个 程序 中 重复 导入 这 个 文件 ， 在 第 2 次 导入 时 
便 会 发 生 错误 ， 因 为 PHP 不 允许 相同 名 称 的 函数 被 重复 声明 。 


第 2 章 PHP 基础 


设计 过 程 
(1) 创建 index.php 文件 ， 通 过 include_once0 语 句 包含 文件 mcphp， 其 代码 如 下 : 

<table><tr><td><?php include_once("ine.php"):?></td></tr></table> // 在 table 标签 中 嵌入 php 包含 语句 
(2) 创建 inc.php 文件 ， 将 图 片 作为 <body> 标 签 的 背景 图 ， 其 代码 如 下 : 

<title> 包 含 头 文件 <title> 

<body background="../image/1 jpg" style="font-size:14px; color#000099: fontfamily-' 微 软 雅 黑 "> 。 / 表 景 

<img ste="image/1.jpg”> /1 引入 图 片 

</body> 
(3) 运行 本 实例 ， 运 行 结果 如 图 2.26 所 示 。 

图 秘笈 心 法 


心 法 领悟 055: 使 用 include_once0 语 句 的 注意 事项 。 
include_once0 语 句 应 用 于 在 脚本 执行 期 间 同一 个 文件 有 可 能 被 包含 超过 一 次 的 情况 下 ， 确 保 指 定 文件 只 被 
包含 一 次 ， 从 而 避免 函数 重复 定义 ， 变 量 重 新 赋值 。 


图 实例 说 明 


require0 语 句 和 include0 语 句 在 作用 上 没有 本 质 区 别 ， 用 户 可 根据 个 人 习惯 选择 使 用 。 本 实例 通过 使 用 
require0 语 句 包含 网 站 尾 文 件 ， 运 行 结果 如 图 2.27 所 示 。 


长 春 市 明日 科技 有 限 公司 
电话 : 0431-84978981 
传真 5 0431-64978981 


en ew nsoFt Cho 


图 2.27 包含 网 站 尾 文件 


图 关键 技术 
本 实例 的 关键 点 是 rerquire0 语 句 的 运用 。require0 语 句 的 详细 说 明 请 参见 实例 053。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 编 写 PHP 标记 ， 通 过 requireO 语 句 包含 文件 inc.php， 其 代码 如 下 : 
es /包含 尾 文件 
创建 inc.php 文件 , 定义 网 站 尾 文件 , 利用 <p> 标 签 将 明日 科技 公司 的 相关 信息 包含 进来 , 其 代码 如 下 : 


<table width="800" height="129" border="1" bordercolor="#CCCCCC" bordercolorlight="#CCCCCC" cellspacing="0"> 
<t> 

<td width="800"><div align="center"> /定义 表格 
<p> 长 春 市 明日 科技 有 限 公司 </p> 
<p> 电 话 : 0431-84978981</p> 
<p> 传 真 : 0431-84978981</p> 
<p>email:www.mrsoft.com</p> 

</div></td> 
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Se 
(3) 运行 本 实例 ， 运 行 结果 如 图 2.27 所 示 。 
图 秘笈 心 法 


心 法 领悟 056: 使 用 requireO 语 句 的 注意 事项 。 
TequireO 语 句 包含 不 存在 的 文件 时 ， 会 出 现 一 个 致命 错误 。 


Ci 加 


图 实例 说 明 


本 实例 通过 使 用 require_onceO 语 句 包含 网 站 主 文件 ， 运 行 结果 如 图 2.28 所 示 。 
名 
心 腕 又 


迎风 


于 


而 粗 轴 其” 洪 | 汕 关 履 


-和 有著 叶 由 放 ”加 轩 岂 各 各 宙 刊 ” 
从 入” 且 贡 肌 阶 淹 区 你 ”让 四 请 冯 


图 2.28 包含 网 站 主 文件 


图 关键 技术 


require_once0 语 句 是 require0 语 句 的 延伸 ， 其 功能 与 require0 语 句 基本 类 似 , 不 同 的 是 在 应 用 require_once0 
语句 时 会 先 检查 要 引用 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 引用 过 ， 如 果 有 ， 则 不 再 重复 调用 该 文件 ， 
例如 ,同时 应 用 require_once0 语 句 在 同一 个 页 面 中 引用 了 两 个 相同 文件 , 那么 在 输出 时 只 有 第 1 个 文件 被 执行 ， 
第 2 次 引用 的 文件 不 会 被 执行 。 


图 设计 过 程 

(1) 创建 indexphp 文件 ， 通 过 switch0 语 句 接收 地 址 栏 传递 的 参数 ， 根 据 参 数 传递 的 数据 引入 通过 
Tequire_ once0 语 句 包含 的 文件 ， 其 代码 如 下 : 

<?php 


switch($_GET[link]){ /通过 get 方 式 接收 地 址 栏 参数 
case "主页 " 
Tequire_once('inc .php)): // 包 含 文件 inc.php 
break: 
case "注册 ' 
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Tequire_once('ine_1.php); // 包 含 文件 inc_1.php 
break; 
case "浏览 "; 
Tequire_once('inc 2.php); /包含 文件 inc 2.php 
break: 
defanlt: 
include(inc.php’); 
} 
> 
(2) 运行 本 实例 ， 运 行 结果 如 图 2.28 所 示 。 
图 秘笈 心 法 


心 法 领悟 057: 使 用 require_once0 语 名 的 注意 事项 。 
require_once0 语 名 与 require0 语 句 一样 ， 当 包含 不 存在 的 文件 时 ， 会 出 现 一 个 致命 错误 。 


2.4 条 件 语句 


条 件 控制 语句 就 是 以 一 定 的 条 件 作 为 依据 ， 根 据 判断 的 结果 确定 执行 哪 一 部 分 代码 ， 而 不 执行 与 该 部 分 代 
码 并 列 的 其 他 代码 。 

在 PHP 中， 条件 控 制 语 句 可 分 为 以 下 两 种 类 型 : 

加 ”站 条 件 控 制 语句 。 

回 ”switch...case 分 支 控制 语句 。 


实 高 | 


实例 说 明 


在 PHP 应 用 中 ， 类 似 生 日 提醒 等 功能 的 程序 随处 可 见 ， 主 要 是 因为 这 样 的 程序 有 一 定 的 定时 效果 。 本 实例 
通过 if0) 语 名 和 foreachO 循 环 语句 实现 一 个 员工 生日 提醒 的 小 程序 ， 如 图 2.29 所 示 。 


员工 生日 提醒 程序 


当前 日 期 : 05 月 28 日 


会 天 是 小 王 的 生日 


图 2.29 员工 生日 提醒 


图 关键 技术 


本 实例 的 关键 点 是 利用 让 选择 语句 ， 将 文本 框 中 的 日 期 与 数组 中 员工 生日 日 期 进行 比较 。 
(1) foreach0 语 句 
foreach0 语 句 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。 
foreach (array_expression as $value) statement: 
参数 array 表示 要 遍历 的 数组 ，expression 表示 键 值 ，$value 表示 键 值 的 对 应 值 ，statement 表示 语句 块 。 
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(2) if0 语 句 

if0 语 句 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ， 否 则 就 跳 过 这 段 程 序 。 
这 expD statement: 

参数 expr 表 示 判 定 条 件 ，statement 表示 语句 块 。 

(3) array0 函 数 


arrayO 函 数 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 => 运算 符 给 出 索引 。 


array array ( [mixed ...]); 
图 设计 过 程 
(1) 创建 index.php 文件 。 首 先 ， 根 据 数组 的 特点 将 键 值 与 对 应 值 存储 在 数组 之 中 ， 然 后， 利用 foreach 语 
句 人 遍历 数组， 将 取得 的 value 值 与 当前 日 期 进行 比较 。 最 后 ， 将 符合 条 件 的 值 进行 输出 ， 其 代码 如 下 : 
和 月 30 日 "" 小 王 "=>"05 月 28 日 "," 小 张 "=>"05 月 29 日 "); /定义 数组 


foreach($a as $key => $value){ /用 foreach 语句 循环 数组 
这 date("m 月 d HH") 一 $value){ 1W 用 让 条 件 语句 进行 比较 
echo "&nbsp;&nbsp; 今 天 是 ".Skey." 的 生日 "; /输出 结果 
} 
» 
> 
(2) 运行 本 实例 ， 运 行 结果 如 图 2.29 所 示 。 
秘笈 心 法 


心 法 领悟 058: 使 用 foreach0 语 句 的 相关 说 明 。 
foreach0 语 句 所 操作 的 数据 是 指定 数组 的 一 个 副本 ， 而 不 是 该 数组 本 身 。 因 此 数组 指针 不 会 被 for each0 结 
构 改 变 ， 对 返回 的 数组 单元 的 修改 也 不 会 影响 源 数 组 。 不 过 源 数 组 的 内 部 指针 的 确 在 处 理 数组 的 过 程 中 向 前 移 


动 了 。 假 定 foreach 循环 运行 到 结束 ， 源 数组 的 内 部 指针 将 指向 数组 的 结尾 。foreach0 语 句 不 支持 用 “@” 来 禁 
止 错误 信息 。 
高 级 | 
趣味 指数 : De 
图 实例 说 明 
本 实例 通过 if0) 条 件 语 句 对 文本 框 中 输入 的 考试 成 绩 进行 评定 和 选择 ， 运 行 结果 如 图 2.30 所 示 。 
办 六 考试 成 绩 。 |100 区 号 | 
成 绩优 秀 
图 2.30 考试 成 绩 评定 标准 
图 关键 技术 


ifO 语 句 是 最 简单 的 条 件 判定 语句 ， 它 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ; 
否则 就 跳 过 这 段 程序 去 执行 下 面 的 程序 。 

本 实例 的 关键 点 是 if0 语 句 的 灵活 运用 。 当 expr 的 值 为 TRUE 时 ， 执 行 statementl 语句 。 

if(expD {statementl:} 

参数 说 明 : 

expr: 条 件 判断 语句 。 
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statement: 符合 条 件 的 执行 代码 。 
图 设计 过 程 
创建 mdex.php 文件 ， 当 单 击 “ 评 定 ” 按 钮 时 ， 程 序 自 动 利用 POST 方法 接收 数据 ， 并 且 利 用 if0 语 句 对 接 
收 的 数据 进行 判断 ， 再 用 echo 语句 输出 结果 ， 其 代码 如 下 : 


if($_POST[sub){ // 通 过 post 方式 传递 参数 
if($_POST[text] 一 100){ /当成 绩 为 100 时 
echo "成 绩优 秀 "; /输出 
} 
这 $_POST[text] >= 60 and $_POST[text] < 100){ /当成 绩 大 于 等 于 60 小 于 100 时 
echo "成 绩 良 好 "; /输出 
} 
if($_POST[text] < 60){ // 当 成 绩 小 于 60 时 
echo "不 及 格 "; /输出 
和 
> 
也 笈 心 法 


心 法 领悟 059: if0 语 句 的 变 体 。 
if0 语 句 有 多 种 变 体 ， 因 此 其 应 用 范围 非常 广泛 ， 在 后 面 的 很 多 实例 中 都 可 以 找到 它 的 身影 。 
高 级 
趣味 指数 : sa | 


实例 


图 实例 说 明 


用 户 在 浏览 一 些 网 站 时 ， 网 站 本 身 会 将 用 户 定义 为 VIP 会 员 或 者 游客 ， 会 员 可 以 享有 更 多 的 权限 ， 而 游客 
对 网 站 的 浏览 有 权限 限制 ， 下 面 就 来 实现 这 一 功能 。 本 实例 通过 计 ..else.… 语 句 实现 对 登录 用 户 权限 的 控制 ， 运 
行 结果 如 图 2.31 所 示 。 


当前 是 YIF 用 户 


2.31 控制 登录 用 户 权限 


图 关键 技术 


大 多 时 候 ， 总 是 需要 在 满足 某 个 条 件 时 执行 一 条 语句 ， 不 满足 时 执行 另 一 条 语句 。 为 了 适应 这 样 的 一 个 需 
求 ， 用 户 可 以 使 用 if0 语 名 的 else 子 句 ， 其 语法 如 下 : 

这 expD {statement1:}else {statement2:} 

如 果 表 达 式 expr 的 值 为 TRUE, 则 执行 statementl 语句 ; 如 果 表达 式 expr 的 值 为 FALSE, 则 执行 statement2 
语句 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 确 定 ”按钮 时 ， 程 序 通过 POST 方法 接收 传递 过 来 的 数据 ， 并 且 通 过 
让 .else.…. 选 择 语句 设 定 条 件 ， 当 符合 条 件 时 利用 echo 语句 输出 “当前 是 VIP 用 户 ”， 否则 输出 “您 只 是 一 个 游 
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客 ”， 其 代码 如 下 : 
<2php 
if($ POSTI'subD){ 


// 判 断 通过 POST 接收 的 参数 结果 是 否 符合 条 件 
if($ POSTTuser]1 一 mr and $ POST['pwd] — mrsoft){ 


echo "当前 是 VIP 用户" // 符 合 条 件 的 结果 
jelsef 
echo "您 只 是 一 个 游客 // 不 符合 条 件 的 结果 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\060\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.31 所 示 。 
图 秘笈 心 法 


心 法 领悟 060: 使 用 逊 ..else.… 语 句 的 优点 。 
让 .else... 语 句 是 寺 语 句 的 另 一 种 形式 ， 结 构 上 相对 让 语句 要 清晰 。 


图 实例 说 明 


类 似 于 留言 板 等 一 些 功能 较 单一 的 网 站 ， 可 以 通过 switch 语句 币 
本 实例 通过 switch0 语 句 、includeO 语 句 来 演示 网 页 框架 的 制作 ， 运 


:网 页 框架 将 所 有 内 容 包含 到 主页 当中 。 
果 如 图 2.32 所 示 。 


用 得 inc， 

本 二 T 

全 尽 座 黄 

筱 欢 明 河 

尽 ， 月 之 

还 甘 骂 水 

竖 使 白天 

裕 达 发 上 

。 榜 ， 来 

FE EE 六 
月 再 叶 ” 汪 三 本 A 


图 2.32 网 页 框架 的 制作 


图 关键 技术 


switchO 语 句 和 break 语句 的 灵活 运用 是 本 实例 的 关键 。 
(1) switchO 语 句 和 具有 同样 表达 式 的 一 系列 的 寺 语 名 相似。 很 多 场合 下 需要 把 同一 个 变量 (或 表达 式 ) 
与 很 多 不 同 的 值 比较 ， 并 根据 它 等 于 哪个 值 来 执行 不 同 的 代码 ， 其 语句 的 格式 如 下 : 
switch(variable){ 
case valuel: 
statementl; 
break; 
case value2: 
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default: 
default statement n: 
3 


switchO 语 名 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比 较 ， 如 果 不 相 等 ， 继 续 查 找 下 一 个 case; 如 
果 相 等 ， 就 执行 对 应 的 语句 ， 直 到 switch 语句 结束 或 遇 到 break 为 止 。 一 般 switch0 语 句 最 终 都 有 一 个 默认 值 
default， 如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 (与 else 语句 类 似 ) 。 

(2) break 语句 用 于 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 利 用 switch0 语 句 获 取 从 地 址 栏 传 递 的 数据 ， 并 且 将 数据 与 switchO 语 名 
中 的 case 做 比较 ,当地 址 栏 传递 的 数据 与 case 中 的 数据 相等 时 ,包含 指定 文件 ,并且 利用 break 语句 跳出 switchO 


语句 ， 其 代码 如 下 : 
<php 
switch($_GET[link']){ /通过 地 址 栏 接收 参数 

case "主页 "; /如 果 值 为 主页 
include('inc.php); /包含 “incphp” 文件 
break; /结束 执行 switch 语句 
case "注册 "; /如 果 值 为 注册 
inclade(inc_1.php)) 
break; 
case "浏览"; // 如 果 值 为 浏览 
include('ine_2.php’): 
break: 
default: / 葡 认 情况 下 ， 包 含 文件 “inc.php” 
include('ine.php'): 


} 

es 

(2) 将 该 文件 存储 于 \MR\02\061\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.32 所 示 。 
图 秘笈 心 法 


心 法 领悟 061: switch0 语 句 的 实现 原理 。 
switchO 语 句 在 执行 时 ， 即 使 遇 到 符合 要 求 的 case 语句 段 ， 也 会 继续 往 下 执行 ， 直 到 switch 结束 。 为 了 避免 
这 种 浪费 时 间 和 资源 的 行为 ， 一 定 要 在 每 个 case 语句 段 后 添加 break 跳 转 语句 跳出 当前 循环 


力 实例 说 明 

验证 码 的 作用 是 防止 用 户 恶意 注册 ， 而 降低 数据 库 和 网 站 本 身 的 性 能 。 本 实例 应 用 switchO 语 句 通过 PHP 
图 像 函 数 来 演示 图 片 验证 码 的 制作 ， 运 行 结果 如 图 2.33 所 示 。 
二 光泽 苇 证 另 受 型 
文字 ”数字 


| 四 


2.33 图 片 验证 码 
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图 关键 技术 


本 实例 的 关键 点 是 验证 码 函数 和 switchO 语 句 的 联合 应 用 ， 其 应 用 到 的 函数 如 下 : 

(1) header0 函 数 

当 参 数 为 Content-type:image/png 时 使 用 header0 函 数 表 示 将 图 片 输出 到 浏览 器 。 

Void header ( string string [, bool replace [, int http_response code]]); 

(2) imagecreatetruecolor() 函 数 

新 建 一 个 真 彩色 图 像 ，imagecreatetruecolor0 函 数 返回 一 个 图 像 标识 符 , 代表 了 一 幅 大 小 为 x_size 和 y_size 
的 黑色 图 像 。 

Tesource imagecreatetruecolor ( int x_size, int y_size); 

(3) imagecolorallocate0) 函 数 

为 一 幅 图 像 分 配 颜 色 ，imagecolorallocate0 函 数 返 回 一 个 标识 符 ， 代 表 了 由 给 定 的 RGB 成 分 组 成 的 颜色 。 
image 参数 是 imagecreate() 函数 的 返回 值 ，red、green 和 blue 分 别 是 所 需要 的 颜色 的 红 、 绿 、 蓝 成 分 。 这 些 参 
数 是 0~255 的 整数 或 者 十 六 进 制 的 0x00~0xFF。imagecolorallocate() 必须 被 调用 以 创建 每 一 种 用 在 image 所 代 
表 的 图 像 中 的 颜色 。 

int imagecolorallocate ( resource image, int red, int green, int blue); 

(4) imagettftext0 函 数 

用 TrueType 字体 向 图 像 写 入 文本 ，imagettftext0 函 数 是 将 字符 串 text 添加 到 image 所 代表 的 图 像 上 ， 从 坐 
标 (X，y) (左上 角 为 0, 0) ) 开始 ， 角 度 为 angle， 颜 色 为 color， 使 用 fontfile 所 指定 的 TrueType 字体 文 
件 。 根据 PHP 所 使 用 的 GD 库 的 不 同 ， 如 果 fontfile 没有 以 "开头 ， 则 'ttf 将 被 加 到 文件 名 之 后 并 且 会 搜 
索 库 定义 字体 路 径 。 

array imagettftext ( resource image, int size, int angle, int x, int y, int color, string fontfile, string text); 

(5) imagegif0 函 数 

以 GIF 格式 将 图 像 输出 到 浏览 器 或 文件 ，imagegif0 函 数 从 image 图 像 以 filename 为 文件 名 创建 一 个 
GIF 图 像 。image 参数 是 imagecreate() 函数 的 返回 值 。 

int imagegif ( resource image [, string filename]); 

(6) int imagestring0) 函 数 

水 平地 画 一 行 字符 串 ，int imagestring0 函 数 用 col 颜色 将 字符 串 s 画 到 image 所 代表 的 图 像 的 (x，y) 坐 
标 处 《图像 的 左上 角 为 0, 0) ) 。 如 果 font 是 1、2、3、4 或 5， 则 使 用 内 置 字体 。 

int imagestring ( resource image, int font, int x, int y, string s, int col); 
图 设计 过 程 

(1) 创建 index.php 文件 , 通过 GET 方式 接收 由 地 址 栏 传递 的 数据 并 且 将 参数 与 case 的 值 进行 比较 ， 当 两 
者 相等 时 引入 指定 图 片 ， 通 过 switchO 语 句 进行 操作 ， 其 代码 如 下 : 


<2php 
switch($_GET[link]){ /取得 通过 地 址 栏 传递 的 参数 
case "文字 "; // 当 参数 等 于 文字 时 
?> 
<img ste="yzm 1.php"> /引入 图 片 
<php 
break: /| 结束 执行 switch0 语 句 
case "数字 "; // 当 参数 等 于 数字 时 
> 
<img sre="yzm 2.php"> /引入 图 片 
<2php 
break; 1/ 结束 执 行 switch0 语 句 
default: / 菊 认 情况 下 
> 
<img sre="yzm 2.php"> 
<?php 
} 
?> 
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(2) 创建 yzm_1.php 文件 ， 应 用 图 像 处 理 函 数 生成 文字 验证 码 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
header("Content-type:image/gif"): // 设 置 页 面 类 型 
S$image = imagecreatetruecolor(80,30); // 创 建 画 布 
S$font = Font/FZHCJW.TTF'; /定义 字体 
$bg=imagecolorallocate($image.255.255.255): /定义 背景 颜色 
$color = imagecolorallocate($image.255,0,255); 

imagettftext($image,20.0.8,20,$color, $font,"mrsoft"); /输出 文字 
imagegif($image); /生成 图 像 

> 

(3) 创建 yzm 2.php 文件 ， 应 用 图 像 处 理 函 数 生成 数字 验证 码 ， 其 代码 如 下 : 
<?php 

header("Content-type:image/gif"); // 设 置 页 面 格式 
Simage = imagecreatetruecolor(40,20); // 生 成 画布 

S$bg = imagecolorallocate($image,225,225,0); /定义 背景 颜色 
$color = imagecolorallocate($image,255,0,255); // 定 义 图 像 颜色 
for($b = 0:$b <4; $b ++){ // 生 成 随机 验证 码 

$a =rand(1,9); 

} 

imagestring($image,3,8,5,$a,$color); /输出 验证 码 
imagegifSimage); /生成 图 像 
> 


图 秘笈 心 法 


心 法 领悟 062: 开启 GD2 支持 。 

PHP 5.0 中 GD2 函数 库 已 经 作为 扩展 被 默认 安装 ， 但 目前 有 些 版 本 中 ， 还 需要 对 php.ini 文件 进行 设置 来 激 
活 GD2 函数 库 。 用 文本 编辑 工具 ， 如 记事 本 等 程序 打开 php.ini 文件 ， 将 文件 中 的 “:extension=php_gd2.dll” 选 
项 中 的 分 号 “;” 删 除 ， 保 存 修改 后 的 文件 ， 并 重新 启动 Apache 服务 器 即 可 激活 GD2 函数 库 。 


趣味 指数 : 会 会 会 会 


力 实例 说 明 


- 些 手 机 在 开机 时 会 出 现 开机 问候 语 或 者 今日 日 程 提示 。 本 实例 就 是 设计 类 似 这 样 的 程序 ， 通 过 switchO 
语句 根据 当前 日 期 ， 给 出 健康 生活 提示 信息 ， 运 行 结果 如 图 2.34 所 示 。 


图 2.34 健康 生活 提醒 


图 关键 技术 


本 实例 的 关键 点 是 利用 switchO 语 句 ， 将 地 址 栏 传递 的 数据 与 switch 中 case 值 进行 比较 ， 符 合 条 件 的 利用 
echo 语句 输出 对 应 数据 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 通 过 date0 函 数 取 得 当前 是 星期 几 ， 然 后 ， 利 用 switchO 语 句 进行 操作 ， 
并 通过 echo 语句 输出 信息 提示 ， 其 代码 如 下 : 
2 $a= date("I"); /取得 当前 是 星期 几 
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Switch($a){ 

case "Monday"; // 当 前 如 果 是 星期 一 
echo "今天 是 星期 一 ， 一 周 忙碌 生活 开始 了 ": /输出 

break; 

case "Tuesday": /当前 如 果 是 星期 二 
echo "今天 是 星期 二 ， 电 视 台 下 午 两 点 以 后 部 分 休息 " /输出 

break: 

case "Wednesday"; /当前 如 果 是 星期 三 
echo "今天 是 星期 三 ， 下 午 有 乒乓 球 比赛 "; /输出 

break: 

case "Thursday"; // 当 前 如 果 是 星期 四 
echo "今天 是 星期 四 ， 晚 上 有 NBA 的 重播 "; /输出 

break; 

case "Friday"; // 当 前 如 果 是 星期 五 
echo "今天 是 黑色 星期 五 。。。。。。 /输出 

break 

case "Saturday": /当前 如 果 是 星期 六 
echo "今天 是 星期 六 ， 明 天 就 放假 了 哈哈 哈 ": /输出 

break; 

case "Sunday"; // 当 前 如 果 是 星期 日 
echo "今天 是 星期 天 ， 可 以 玩 上 一 整 天 "; /输出 


上 
> 
(2) 将 该 文件 存储 于 \MR\02\063\ 文 件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.34 所 示 。 
图 秘笈 心 法 
心 法 领悟 063: 比较 switch0 语 句 与 站 ..else... 语 句 。 


switchO 语 名 与 让 .else... 语 句 在 功能 上 基本 相同 ， 但 是 switch0 语 句 更 加 灵活 ， 格 式 更 加 鲜明 ， 结 构 更 加 
清晰 。 


2.5 循环 控制 


在 实际 应 用 中 ， 经 常会 遇 到 一 些 操作 并 不 复杂 ， 但 需要 反复 处 理 的 问题 ， 为 此 ，PHP 提供 了 循环 语句 来 实 
现 循环 结构 的 程序 设计 。 循 环 控制 语句 是 指 能 够 按照 一 定 的 条 件 重 复 执行 某 段 功能 代码 的 代码 结构 。 循 环 控制 
语句 分 为 以 下 4 种 : 
while 循环 语句 。 
do...while 循环 语句 。 
for 循环 语句 。 
foreach 循环 语句 。 


图 图 回回 


力 实例 说 明 


while 循环 结构 的 作用 是 重复 执行 一 段 代码 或 完成 相同 的 动作 。 本 实例 通过 while0 语 句 循环 输出 数组 中 存储 
的 员工 生日 信息 ， 运 行 结果 如 图 2.35 所 示 。 


86 年 6 月 2 日 是 张 2 的 生日 
86 年 6 月 5 日 是 张 3 的 生日 
86 年 6 月 4 日 是 张 4 的 生日 


86 年 6 月 4 日 是 张 4 的 生日 
36 年 5 月 5 日 是 张 5 的 生日 
86 年 6 月 6 日 是 张 6 的 生日 
35 年 6 月 7 日 是 张 7 的 生日 
I86 年 6 月 ?日 是 张 7 的 生日 


图 2.35 员工 生日 列表 


力 关键 技术 


while 循环 是 PHP 中 最 简单 的 循环 控制 语句 。whileO 循 环 语句 根据 某 一 条 件 进行 判断 ， 决 定 是 否 执行 循环 ， 


} 
当 表 达 式 expr 的 值 为 tue 时 ， 将 执行 statement 语句 ， 执 行 结束 后 ， 再 返回 到 expr 表达 式 继续 进行 判断 。 
直到 表达 式 的 值 为 false 才 跳 出 循环 ， 执 行 大 括号 后 面 的 语句 。 


创建 index.php 文件 。 首 先 ， 利 用 数组 函数 将 数据 信息 存储 在 数组 变量 中 。 然 后 ， 定 义 循环 变量 的 初始 值 为 
0， 最 大 值 不 超过 数组 长 度 ， 并 在 循环 内 部 做 自 增 运算 。 最 后 ， 利 用 while 循环 输出 结果 ， 其 代码 如 下 : 
<?php 


S$a=array("86 年 6 月 1 日 是 张 1 的 生日 ""86 年 6 月 2 日 是 张 2 的 生日 ""86 年 6 月 3 日 是 张 3 的 生日 ""86 年 6 月 4 日 是 张 4 的 生日 ""86 
年 6 月 4 日 是 张 4 的 生日 ""86 年 6 月 5 日 是 张 5 的 生日 ""86 年 6 月 6 日 是 张 6 的 生日 ""86 年 6 月 7 日 是 张 7 的 生日 ""86 年 6 月 7 日 是 张 7 


的 生日 "); // 定 义 数组 
$b=0; /给 变量 赋 初 始 值 
while($b < count($a){ /根据 数组 长 度 循环 输出 
echo $a[$b]."<br><br>"; /输出 数组 元 素 
Sb++; 
上 
> 
图 秘笈 心 法 


心 法 领悟 064: 介绍 while0 语 句 的 变 体 。 
while0 循 环 语句 还 有 另 一 种 表示 形式 ， 即 do...while， 详 细 说 明 请 参见 实例 065。 


高 级 | 
趣味 指数 : 食 夫 全 本 


图 实例 说 明 
本 实例 通过 do...while 循环 语句 循环 读 取 数 据 库 中 的 数据 , 输出 员工 的 详细 信息 ,运行 结果 如 图 2.36 所 示 。 
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生日 期 月 站 
: 25 出 生日 期 ，1985-06-06 所 在 地 址 。 吉林 省 长 春 市 ”QQn 284126974| 


: 25” 出 生日 期 : 0000-00-00 了 所 在 地 址 ， 宋 代 浏 梁 ”QQ，xxkxxx 效 
: “25 出生 日期，0000-00-00 所 在 地 址 ， 宋代 汗 梁 QQ， xxxxxxxxx 


图 2.36 员工 详细 信息 浏览 


键 技术 


while0 语 句 还 有 另外 一 种 表示 形式 ， 即 do...while。do...while 循环 语句 和 while 循环 语句 非常 类 似 ， 只 是 
do.…while 循环 语句 在 循环 底部 检测 循环 表达 式 ， 而 不 是 在 循环 的 顶部 进行 检测 。do.…while 循环 语句 的 语法 格 
式 如 下 : 

dof 

statment 
}while(expr); 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 mysql_connect0 函 数 连接 MySQL 数据 库 ， 并 通过 mysql_query 函数 
定义 页 面 的 编码 格式 。 然 后 ， 定 义 SQL 查询 语句 并 返回 结果 集 。 最 后 ， 通 过 do.…while 语句 循环 输出 数据 库 中 
的 数据 ， 其 代码 如 下 : 


<?php 

Sconn = mysql_connect("localhost","root","111") /连接 数据 库 服务 器 
mysql_select_db("db_database02".Sconn); /连接 数据 库 
mysql_query("SET NAMES GBK"); /设置 编码 格式 

S$rs = mysql_query("select * from tb_while"); /执行 查询 

dof 


echo "姓名 : "iconv('gbk'wutf-8',Srst[1])."&nbsp:&mnbsp: 年 龄 : "iconvCgbk'utf-8',Srst[2])."&nbsp:&mnbsp: 出 生日 期 : 
"iconvCgbk'vutf-8'Srst[3])."S&nbsp:&nbsp; 所 在 地 址 : ".iconv('gbk',"utf-8',$rst[4])."&nbsp;&nbsp:QQ: ".iconv(gbk',"utf-8',$rst[5])."<br><br>"; 
}while($rst = mysql_fetch_array($rs)): 
> 
(2) 将 该 文件 存储 于 \MR\02\065\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.36 所 示 。 


图 秘笈 心 法 


心 法 领悟 065: 使 用 do...while 语句 的 注意 事项 。 
在 使 用 do...while 语句 之 前 ， 要 考虑 程序 是 否 有 必要 在 判断 条 件 之 前 运行 一 次 ， 如 果 没 有 必要 ， 尽 量 不 要 
使 用 该 语句 ， 和 否则 可 能 会 出 现 意外 的 输出 结果 。 


力 实例 说 明 

在 操作 数据 库 的 过 程 中 可 能 会 出 现 很 多 无 用 的 匈 余 信息 ， 可 以 使 用 
while0 循 环 语句 将 其 循环 删除 。 本 实例 通过 while0 循 环 语句 实现 员工 信息 的 
批量 删除 ， 运 行 结果 如 图 2.37 所 示 。 


考 除 3 | 


朵 记录 [@O 于 ] 
为 阳 天 的 员工 已 被 光 

为 郭靖 的 员工 已 被 删除 
由 名 为 黄 奔 的 员工 已 被 开除 


图 2.37 员工 信息 的 批量 删除 


图 关键 技术 


本 实例 的 关键 点 是 while0 循 环 语句 的 灵活 运用 。 根 据 提交 的 参数 值 ， 执 行 while0 循 环 语句 ， 在 循环 体 中 执 


行 删除 操作 ， 完 成 数据 的 循环 删除 操作 。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 。 首 先 ， 连 接 MySQL 数据 库 服 务 器 ， 选 择 MySQL 中 名 称 为 db_while 的 数据 库 ， 
并 设置 页 面 的 编码 格式 。 然 后 ， 定 义 循环 变量 $a 和 $b， 将 第 1 层 while 循环 中 的 循环 条 件 设置 为 Sb<$a， 然 后 ， 
再 次 利用 while 语句 循环 输出 数据 表 中 的 数据 ， 并 执行 数据 的 删除 操作 ， 其 代码 如 下 : 
<2php 


if($_POST[sub]) { 


Sconn = mysql_connect("localhost","root","111"); 


mysql_select_db("db_while",Sconn); 
mysql_query("SET NAMES GBK"): 
$a=$_POST[te]; 
$b=0; 

while($b < $a){ 


Srs = mysql_query("select * from tb_while"); 
while(Srst = mysql_fetch_amray(Srs)){ 
S$sql = "delete * from tb_while where id = $b"; 


mysql_query($sql); 


echo "姓名 为 ".$rst[name]." 的 员工 已 被 删除 <br>"; 


Sb++; 


: 


| 
?> 


/通过 POST 方式 获取 参数 
/连接 mysql 数据 库 

/连接 数据 库 

/定义 编码 格式 

/| 接收 文本 框 参数 

// 定 义 变量 

/while 循环 

/执行 查询 操作 

// 将 查询 结果 保存 在 数组 中 
/lsql 语句 

/执行 删除 操作 

/输出 被 删除 的 员工 姓名 


2) 将 该 文件 存储 于 \MR\02\066 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.37 所 示 。 


力 秘笈 心 法 


心 法 领悟 066: 使 用 while0 语 句 嵌 套 的 注意 事项 。 


图 实例 说 明 


很 多 时 候 PHP 编码 需要 和 HIML 编码 混 编 ,例如 ,输出 表格 打印 html 标签 等 。 
本 实例 应 用 两 层 forO0 语 句 循环 制作 动态 表格 ， 运 行 结 果 如 图 2.38 所 示 。 


图 关键 技术 


加 上 四 加 四 四 四 加 
加 四 四 四 四 四 四 加 
加 由 


图 2.38 表格 的 动态 创建 


for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循环 语句 能 够 按照 已 知 的 循环 次 数 进行 循环 操作 ， 主 要 应 用 于 多 
条 件 情况 下 的 循环 操作 ， 不 适合 在 单一 条 件 下 使 用 。 这 一 点 从 该 语句 的 语法 中 就 可 以 看 出 ， 其 条 件 的 表达 式 有 


3 个 ， 语 法 格式 为 : 


for (exprl; expr2; expr3){ 
statement: 


了 
其 中 ,exprl 为 变量 初始 赋值 ;expr2 为 循环 条 件 , 即 在 每 次 循环 开始 前 求 值 。 如 果 其 值 为 真 , 则 执行 statement， 
否则 ， 跳 出 循环 ， 继 续 往 下 执行 ，expr3 为 变量 递增 或 递 碱 ， 即 每 次 循环 后 被 执行 。 
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设计 过 程 
(1) 创建 PHP 脚本 文件 。 首先， 定义 for 循环 中 的 循环 变量 ga。 设 定 $a 的 初始 值 为 0， 最 大 值 为 4， 并 且 
每 执行 一 次 循环 就 做 一 次 自 增 运 算 。 然 后 ， 利 用 循环 霸 套 的 知识 定义 内 层 循环 ， 内 层 循 环 的 循环 变量 gb 的 初始 


值 为 0， 最 大 值 为 7， 并 且 同 样 做 自 增 运算 。 最 后 ， 利 用 echo 语句 输出 信息 ， 其 代码 如 下 : 
<?php 


for($a=0;$a < 5;:$at+){ 作 层 for 循环 
echo "<table border="1'bordercolor=#000099' bordercolorlight=#000099' cellspacing=0>"; 
echo "<tr>"; /表格 标签 
for($b = 0:$b < 8:$b++){ /全 层 for 循环 
echo "<td>"; /表格 标签 
echo $b; /输出 数据 
echo “</td>"; 
} 
echo "</tr>"; 
echo "</table>"; 
} 


加 
(2) 将 该 文件 存储 于 \MR\02\067 文件 夹 下 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.38 所 示 。 
图 秘笈 心 法 
心 法 领悟 067: for0 循 环 语句 。 
for0 循 环 语句 在 PHP 循环 结构 中 比较 常用 ， 结 构 也 比较 简单 。 所 以 一 定 要 灵活 掌握 此 循环 语句 。 在 本 实例 
中 ,虽然 其 定义 变量 的 最 大 值 为 4 和 7， 但 是 ， 由 于 在 for 循环 中 ， 其 条 件 表达 式 的 值 是 从 等 于 0 开始 ， 所 以 循 
环 语句 分 别 执行 了 5 次 和 8 次 。 


车 中 数据 的 读 取 高 级 
2 { 


实例 068 
力 实例 说 明 


购物 车 是 电子 商务 系统 中 的 常见 模块 ， SESSION 作为 一 种 会 话机 制作 用 不 可 小 凯 。 本 实例 综合 运用 while0 
语句 、switch0 语 名 、if0 语 句 和 for 0 语句 实现 一 个 简单 的 SESSION 购物 车 功能 ， 运 行 结 果 如 图 2.39 所 示 。 


种! 


2.39 SESSION 购物 车 中 数据 的 读 取 
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图 关键 技术 


(1) 通过 switchO 语 句 根据 地 址 栏 中 传递 的 参数 值 ， 实 现在 不 同 商品 页 面 之 问 的 跳 转 。 
(2) 通过 if0 语 名 对 form0 表 单 提交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 
(3) 通过 while0 语 句 和 for0 语 句 完成 购物 车 中 购买 商品 的 输出 。 
图 设计 过 程 
(1) 创建 ndex php 文件 , 通过 switchO 语 句 根据 地 址 栏 中 传递 的 参数 值 ， 实现 在 不 同 商品 页 面 之 问 的 跳 转 ， 
其 代码 如 下 : 
<?php 
switch($ GETflinkD)f 
case "电脑 "; 
include_once("in_1.php"); 
break; 
case "家 庭 影院 "; 
include once("in 2.php"); 


break: 

case "全 自动 洗衣 机 ": 
include once("in 3.php"); 
break; 

case "数码 摄像 机 "; 
inclode once("in 4.php"); 


break; 

case "山地 自行 车 "; 

include_once("in_5.php"); 

break; 

default: 

include_once("in_image.php"); 
bi : 


(2) 创建 config.php 文件 。 首 先 ， 编 辑 form 表单 ， 执 行 不 同 的 操作 。 然 后 ， 应 用 if0 语 句 根 据 form 表单 
提交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 最 后 ， 通 过 while0 和 for0 语 句 循环 输出 购物 车 中 存储 的 商品 ， 其 关 
键 代码 如 下 : 

<form action="" method="post"> 
我 要 购买 <input type="text" size="2" value ="1" name="num"> 件 
<input type="submit" name="sub" value=" 放 入 购物 车 " style="background-image:url(pic/button_2.jpg);color:red"> 
<input type="submit" name="sub1" value=" 结 账 " style="background-image:url(pic/button_3.jpg):color:red"> 
<input type="submit" name="sub2" value=" 首 页 " style="background-image:url(pic/button_1.jpg);color:red"> 
</form> 
<?php 
这 $_POST[sub2]){ 
echo "<script>location.href='index.php'</script>"; 


1 
if($ POST[subD{ 
S$str = explode("#",$_SESSION[id]): 
include("class/mysql.php"); 
$sql = "insert into tb_shop(idname .numbermoney.moneyother.otheDvalues(""Sstr[0].Sstr[1],…Sstr[2].Sstr[3]…Sstr[4]7" 
这 mysql_ query(SsqD){ 
mysql_close(Sconn): 
echo "<script>alert( 已 经 放 入 购物 车 ")</script>"; 
} 


} 

if$_POST[sub1] || $_GET['sub1D){ 
Tequire once("class/mysql.php"); 
$sq = "select * from tb_shop": 
Srs =mysql_query($sq); 


<form action ="config/table php" method="post"> 
<input type="submit" name="sub3" value=" 删 除 " style="background-image:-url(pic/button_3.jpg):color:red"> 
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</form> 
<Iphp 
while($rst = mysql_fetch row(Srs)) 
for($a= 0;$a < 6:$atH{f 
<tr><td><?php echo $rst[$a]?></td></tr> 


1 


MM 


</table> 
<a href="config/money.php"><img sre="pic/bujpg"></a> 


} 


> 
(3) 创建 table.php 文件 ， 执 行 删除 指定 商品 的 操作 ， 其 关键 代码 如 下 : 
<?php 


<2pbp 


require_once("../class/mysql.php"); // 包 含 数据 库 连 接 文件 
$sq = "select * from tb_shop"; // 定 义 SQL 查询 语句 
Srs = mysql_query($sq); // 执 行 查询 操作 
> 
<table> 
<?php 
‘while($rst = mysql_fetch row($rs){ /循环 输出 商品 信息 
> 
<tr><td> 商 品 编码 :<?php echo S$rst[0]:?></td><td> 商 品名 称 : <?php echo S$rst[1]:?></td></tr> 
<tr><td> 购 买 数量 。<?php echo $rst[2]:?><hr></td><td> 金 额 总 计 : <?php echo S$rst[3]:?><hr></td></tr> 
<!--tr><td> 商 品 运费 ，<?php echo S$rst[4]:?><hr></td><td> 其 他 声明 : <?php echo $rst[5];?><hr></td></tr--> 
<?php 
} 
> 
</td> 
</tr></table></td></tr></table> 
<?php 
if($_POST[sub4]){ 
$sqlser = "delete from tb_shop where id ="'$_POST[tt]"; // 定 义 SQL 语句 
if(mysql_query($sqlser){ /执行 删除 操作 
echo "<script>alert( 商品 删除 成 功 )</script>”: 


echo "<script>window.location_ href="table.php';</script>"; 
和 
这 $_POST[sub5]){ 
echo "<script>window.location.href="../index.php?link= 电 脑 &sub1=1';</script>"; 
a 
?> 


《4) 编辑 mysqlphp 文件 ， 实 现 与 数据 库 的 连接 。 


力 秘笈 心 法 


心 法 领悟 068: 知识 对 接 。 
购物 车 的 知识 相对 较 复杂 ， 在 本 书 第 5 章 的 实例 266 中 将 对 购物 车 进行 详细 讲解 。 


力 实例 说 明 
员工 信息 一 般 存 在 于 人 事 信 息 平台 的 后 台 系 统 中 , 对 员工 信息 的 管理 本 身 可 以 作为 一 个 典型 的 模块 被 使 用 。 
本 实例 通过 for 0 循环 语句 实现 对 员工 数据 的 读 取 、 修 改 和 删除 操作 ， 运 行 结果 如 图 2.40~ 图 2.42 所 示 。 
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图 2.40 员工 数据 的 读 取 图 2.41 员工 数据 的 删除 


EI EN ENN EIEN ES 


未 自 http://localhost 的 页 面 说 : 网 


fh 
CE 


图 2.42 员工 数据 的 修改 


图 关键 技术 

本 实例 通过 forO 循 环 语句 读 取 查询 结果 集中 的 数据 ， 完 成 数据 的 循环 输出 ， 并 且 创建 删除 和 修改 超 链接 ， 
应 用 if 语句 对 超 链接 传递 的 参数 值 进行 判断 ， 实 现 对 数据 的 删除 和 修改 操作 。 有 关 for0 循 环 语句 的 详细 说 明 ， 
请 参见 实例 067， 有 关 if0) 语 句 的 详细 讲解 请 参考 实例 059。 
图 设计 过 程 

创建 index.php 文件 。 首 先 ， 连 接 MySQL 数据 库 ， 执 行 查询 操作 ， 取 得 查询 结果 集 。 然 后 ， 通 过 forO 语 名 
循环 输出 结果 集中 的 数据 。 最 后 ， 通 过 ifO 语 句 对 超 链接 的 参数 值 进行 判断 ， 进 而 执行 删除 和 修改 操作 ， 其 关键 


代码 如 下 : 
<?php 
Slink = mysql pconnect("localhost" "root". "111"); /连接 mysql 
Inysql_select_db("db_database02".Slink): /连接 数据 库 
mysql_query("SET NAMES GBK"): // 设 置 编码 格式 
$query = "SELECT * FROM tb for 1"; //SQL 语句 
Sresult = mysql_query($query); /| 执行 查询 操作 
for ($i= mysql_num rows(S$result) - 1: Si > 一 0: Si--) { //for 循环 
让 (Imysql_data_seek(Sresult $i)) { // 如 果 指 针 不 向 下 移动 
echo "Cannot seek to row $i: " . mysql_errorO . "\n": 
continue; 
} 
if(!($row = mysql_fetch_object(Sresulb)) // 如 果 结 果 集 不 存在 
continue; 


echo "<tr><td>$row->name</td><td>Srow->age</td><td>$row->sex</td><td>$row->tel</td><td>$row->address</td> 
<td><a href="1.php?id=$row->id&edelete=1><b> 删 除 </b></a>&nbsp:&cnbsp;<a href="1.php?id=$row->id&update=1><b> 修 改 
/b></a><hd></tr>"; 
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} 
mysql free_result($result); /局 放 结果 集 
这 $_GET[delete] — D){ /如果 地 址 栏 参数 delete 等 于 1. 
$sql = "delete from tb for 1 where id='$ GET[id]": JSQL 语句 
这 mysql_query(SsqD){ /执行 删除 操作 
echo "<script>alert( 删 除 成 功 ):location-hre 人 >"1.php'</script>"; /| 提示 框 信息 
} 
if($_GET[update] — D{ // 如 果 地 址 栏 参 数 update 等 于 1. 
$sql = "select * from tb_for_1 where id ='$_GET[id]"; JSQL 语句 
Srs = mysql_query($sq); /| 执行 查询 语句 
Srst = mysql_fetch_array(Srs): /取得 结果 集 
> 
</table><br><br> 
<form action="" method="post"> /| 表单 
/使 文本 框 初始 值 为 数据 库 中 结果 
<input name="name" type="text" value="<?php echo $rst[name]:?>" size="6"> 
<input name="age" type="text" value="<?php echo S$rst[age]:?>" size="6"> 
<input name="sex" type="text" value="<?php echo S$rst[sexl]:?>" size="6"> 
<input name="tel" type="text" value="<?php echo S$rst[tel]:;?>" size="11"> 
<input name="address" type="text" value="<?php echo S$rst[address]:;?>" size="6"> 
<input type="submit" name="subl" value=" 修 改 "> 
</form></td></tr></table></td></tr></table> 
<?php 


这 $_POST[subl]){ /如 果 按 钮 被 单 击 
S$sql = "updatetb for 1 set name ='$ POST[namel',age ='$ POST[agel.sex ='$ POST[sexl'tel ='$ POST[tell,address = 
号 POST[address] where id = SGET[id]":/sql 语句 


if(mysql_query($sqD){ /执行 更 新 操作 
echo "<script>alert( 收 改 成 功 ");location.href='1.php'</script>"; /提示 框 信息 
} 


} 
?> 


图 秘笈 心 法 


心 法 领悟 069: 使 用 地 址 栏 传递 参数 存在 风险 。 
通过 地 址 栏 传递 参数 是 存在 风险 的 ， 一 般 情况 下 应 使 用 POST 方式 传递 参数 。 如 果 一 定 要 使 用 GET 方式 传 
递 参数 ， 最 好 应 用 urlencode0 函 数 对 参数 进行 编码 。 


实例 070 趣味 指数 ， 傅 请 请 六 


力 实例 说 明 


在 编程 世界 里 ， 算 法 是 一 门 独立 于 语法 、 函 数 之 外 的 知识 。 它 着 重 考验 用 户 的 逻辑 思维 能 力 并 且 与 数学 知 
识 息息相关 。 本 实例 通过 forO 循 环 语句 实现 网 页 版 九 九 乘法 表 ， 运 行 结 果 如 图 2.43 所 示 。 


[2 

人 2|2t Oi=4 

BB* l= 2 =6 [5 二 3=9 

全 1 =4| 生 和 ZE8 |4 直 3 =12|4 未 生 =16 

5 * 1 =5|5 * 20z10|5,*,3) =15l5 + 4 =20|5 + 5 =25 

6 * 1 =6|6 * 2 S12l6 # 3 =18|6 * 4 =24|6 * 5 =30|6-*# 6 =36 

P77 #2 =1dl7 # 3 =217 * =28|7 + 5 =35| +* 6 =42|l7 + P=d9 

B=88 #2 3168 # 3 =24l8 * =32|8 +05 =40|8 + 6 =48|8 + T=56|8 +# E64 

[9 #1 =99# 2 =18|9 # 3 =27|9 * 4 =36|9 5i=d45|9 + 6 =54|9 + 7 =63|9 + 8.=72|9 + 9 =81| 


2.43 ”网 页 版 九 九 乘法 表 
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力 关键 技术 
本 实例 的 关键 点 是 利用 for 循环 中 的 第 2 层 循环 控制 第 1 层 循环 ， 以 实现 指定 数据 的 输出 。 
设计 过 程 
(1) 创建 PHP 脚本 文件 ， 定 义 1 层 循环 中 的 循环 变量 为 ga， 设 置 $a 的 初始 值 为 1， 最 大 值 为 9， 并 且 每 执 


行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 定 义 内 层 循环 中 的 循环 变量 为 Sb， 设 置 $9b 的 初始 值 为 1， 最 大 值 小 于 9a， 
并 且 做 自 增 运 算 。 最 后 ， 将 2 层 循环 控制 的 数据 输出 到 页 面 ， 其 代码 如 下 : 


<?php 
for($a = 1;$a < 10;$a++){ 作 层 循环 
echo “<tr>"; 
for($b = 1:$b <= $a:$b++){ /2 层 循环 控制 1 层 循环 输出 
echo "<td>"; 
echo "$a * $b =".$a+$b; /| 输出 结果 
echo"</td> 
} 
echo "</tr>" 
} 
(2) 将 该 文件 存储 于 \MR\02\070 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.43 所 示 。 
图 秘笈 心 法 


心 法 领悟 070: 形成 良好 的 算法 思维 。 
算法 不 是 一 朝 一 夕 就 可 以 掌握 的 ， 是 一 个 慢 慢 了 解 、 形 成 思想 的 过 程 。 


实例 071 


实例 说 明 

用 户 在 进行 开发 时 ， 没 有 必要 将 小 型 的 数据 与 数据 库 进 行 交互 ， 可 以 直接 将 其 存 入 数组 ， 这 样 不 仅 可 以 节 
约 开发 时 间 ， 还 可 节省 服务 器 资源 。 本 实例 通过 对 数组 函数 的 相关 操作 实现 读 取 数组 购物 车 中 的 数据 ， 和 运行 结 
果 如 图 2.44 所 示 。 


运 英 ;30 元 《自驾 》 
图 2.44 实现 读 取 
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图 关键 技术 


本 实例 的 关键 点 是 运用 foreach0 语 句 遍 历数 组 , 取得 key 值 和 对 应 的 value 值 。foearch 循环 在 PHP 4.0 中 擅 
长 处 理 数 组 ， 是 遍历 数组 的 一 种 简单 方法 ; 在 PHP 5.0 中 ， 新 增加 了 对 对 象 的 支持 。 该 语句 的 语法 格式 为 : 

foreach (array_expression as $value) 

statement 

或 

foreach (array expression as $key => $value) 

statement 

forearch0 语 句 将 遍历 数组 array_expression, 每 次 循环 时 ,将 当前 数组 中 的 值 赋 给 $value( 或 是 $key 和 $value)， 
同时 ， 数 组 指针 向 后 移动 ， 直 到 遍历 结束 。 当 使 用 foreach0 语 句 时 ， 数 组 指针 将 自动 被 重 置 ， 所 以 不 需要 手动 
设置 指针 位 置 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 字符 串 变 量 ， 并 且 在 变量 中 插入 “#” 作 为 字符 串 分 割 点 。 然 后 ， 利 
用 GET 方式 接收 地 址 栏 传 递 的 参数 。 当 $_GET[push] 的 值 等 于 1 时 ， 输 出 JavaScript 成 功 提示 。 当 $_GET[pop] 


的 值 等 于 1 时 ， 利 用 字符 串 拆 分 函数 将 字符 串 变 量 以 # 分 割 ， 并 分 别 保存 到 数组 之 中 。 最 后 ， 利 用 foreachO 语 句 
将 字符 串 数组 中 的 value 值 输出 到 页 面 中 ， 其 代码 如 下 : 


S$str= "宝贝 ， 液晶 电脑 显示 器 # 一口 价 ;900 元 # 运 费 : 30 元 (自理) "; /定义 字符 串 


if($_GET[push] 一 D){ /通过 GET 方 式 取得 参数 
echo "<script>alert( 成 功放 入 购物 车 ");</script>"; /提示 消息 
} 
if($_GET[pop] — D{ /通过 GET 方式 取得 参数 
Sstrexplode = explode("#".$str); /分割 字符 串 
foreach($strexplode as $key => Svalue){ / 禹 历数 组 
> 
<tr><td><?php echo $value:?></td></tr> /输出 结果 
<?php 


} 
} 


Vs 
(2) 将 该 文件 存储 于 \MR\02\071 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.44 所 示 。 
图 秘笈 心 法 


心 法 领悟 071: 对 于 foreach0 语 句 的 说 明 。 
foreachO 语 句 仅 能 用 于 数组 , 当 试 图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 . foreach() 
语句 不 支持 用 “@” 来 禁止 错误 信息 。 


力 实例 说 明 
用 户 注册 后 ， 系 统 为 了 保存 用 户 的 一 些 基本 信息 ， 包 括 用 户 名 、 密 码 等 相 测 二 己 -- 


关 信 息 ， 以 及 跟踪 和 定位 不 同 用 户 ， 从 而 更 好 地 服务 于 用 户 ， 同 时 ， 为 了 提高 iE, [| E23Pq a 
站 点 的 安全 性 ， 避 免 由 于 网 速 慢 造 成 用 户 注册 信息 的 重复 提交 ， 往 往 会 在 用 户 
注册 表 中 增加 验证 码 功能 。 本 实例 通过 for 循环 实现 图 像 验证 码 的 生成 ,运行 。 图 2.45 图 像 验证 码 的 生成 
结果 如 图 2.45 所 示 。 
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图 关键 技术 

本 实例 的 关键 点 是 for0 循 环 语句 和 rand0 函 数 的 灵活 运用 。 通过 for0 循 环 输出 一 个 包含 4 个 图 像 的 验证 码 ， 
验证 码 的 取 值 由 随机 函数 rand0 生 成 。 

Tand0 函 数 ， 可 产生 一 个 随机 整数 ， 其 语法 如 下 : 

int rand ( [int min int max] ) 


如 果 没 有 提供 可 选 参数 min 和 max，rand0 返 回 0 到 RAND_MAX 之 间 的 伪 随 机 整数 。 例 如 想得到 2~8( 包 
括 2 和 8) 之 间 的 随机 数 ， 则 写 为 rand(2, 8)。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 数组 函数 定义 数组 并 分 别 将 图 片 的 地 址 信息 存 入 到 数组 之 中 。 然 后 ， 


在 for 循环 的 循环 体内 ， 利 用 随机 函数 取得 0~3 中 的 随机 数字 并 保存 在 变量 $rand 中 。 最 后 ， 利 用 拼接 字符 串 的 
方法 输出 图 片 ， 其 代码 如 下 : 
<?php 


Sarray = array("pic/22.jpg"."pic/3.jpg","pic/4.jpe"."pic/5.jpg"): /定义 数组 
for($a = 0:$a < 4;Sat+jf //for 循环 
Srand = rand(0,3); /10~3 的 随机 数字 
echo "<img src = '$array[$rand]>"; /输出 图 像 
要 } 
(2) 将 该 文件 存储 于 \MR\02\072 文件 夹 中 ， 命 名 为 index.php。 运 行 结 果 如 图 2.45 所 示 。 
图 秘笈 心 法 


心 法 领悟 072: 图 像 验证 码 的 刷新 。 
在 本 实例 中 ， 通 过 重新 链接 到 首页 来 实现 验证 码 的 刷新 操作 。 


2.6 跳 转 语句 


跳 转 控制 语句 包括 break 和 continue 两 个 。 其 中 break 语句 可 以 终止 当前 的 循环 ， 而 continue 语句 只 能 终止 
本 次 循环 ， 并 进入 到 下 一 次 循环 中 。 
高 级 


实例 073 趣味 指数 ， 请 亢 商 商 | 


图 实例 说 明 
break 语句 的 含义 是 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 本 实例 通过 breakO 
语句 实现 控制 页 面 中 表情 图 的 输出 ， 运 行 结果 如 图 2.46 所 示 。 


6 贷 各 " 别 获 ,0 生 写 ?可 次 [ai 
号 


2.46 控制 页 面 中 表情 图 的 输出 


图 关键 技术 
使 用 break 关键 字 可 以 终止 当前 的 循环 , 包括 while、do...while、for、 foreach 和 switch 在 内 的 所 有 控制 语句 ， 
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其 在 for0 语 句 中 的 应 用 示例 如 下 : 


for($i=1;$i<=4:$iH){ /应 用 for 循环 控制 语句 输出 表情 头像 
这 Si 一 4){ /1/ 判 断 变量 是 否 等 于 4 
break; /如 果 等 于 4， 使 用 break 语句 跳 转 循环 


} 
本 实例 将 break 语句 与 switchO 语 句 联合 使 用 ， 控 制 页 面 中 表情 图 的 输出 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “确定 ”按钮 时 ， 利 用 switchO 语 名 选择 输出 的 图 片 并 通过 break 语句 跳 
出 当前 switch0 语 句 ， 其 代码 如 下 : 


<?php 
这 $_GET[sub]){ /通过 GET 方式 接收 参数 
switch($_GET[check]){ /lswitch0 语 名 
case "1"; /如 果 值 为 1 
echo "<img src=image/1 .gif >"; /输出 图 像 1 
break; /跳出 语句 
case "2"; /如 果 值 为 2 
echo "<img sre=image/2.gif >"; /输出 图 像 2 
break; 1/ 跳出 语句 
case "3"; /如 果 值 是 3 
echo "<img src=image/3.gif>"; /输出 图 像 3 
break; /跳出 语句 
Case "4"; /如 果 值 为 4 
echo "<img src=image/4.gif>"; /输出 图 像 4 
break; /跳出 循环 
} 
| 


> 
(2) 将 该 文件 存储 于 \MR\02\073 文件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.46 所 示 。 
图 秘笈 心 法 


心 法 领悟 073: break 语句 的 妙用 。 
break 语句 可 以 接受 一 个 可 选 的 数字 参数 来 决定 跳出 几 重 循 环 。 


实例 074 


趣味 指数 : 会 会 例会 


图 实例 说 明 


break 语句 可 以 指定 跳出 循环 的 层 数 ， 一 般 被 用 在 控制 条 件 方面 。 本 实例 通过 break 语句 实现 控制 页 面 中 数 


YOIVYIDIHDIYYYYYD 
ZIIYIVYD 
图 2.47 控制 页 面 中 数据 的 输出 数量 
图 关键 技术 
本 实例 运用 break 语句 跳出 指定 的 几 重 循环 ， 其 语法 格式 如 下 : 
break n: 
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设计 过 程 


(1) 创建 PHP 脚本 文件 。 首先， 利用 多 重 for 循环 霸 套 输出 全 部 图 片 。 然 后 ， 在 多 重 嵌 套 中 定义 if0) 条 件 
语句 ， 当 变量 $rand 中 的 随机 数值 为 2 时 ， 跳 出 3 重 循环 。 和 否则 ， 正 常 输出 图 片 ， 其 代码 如 下 : 
<?php 


for($a =0;$a < 2;$at+){ 
for($b= 0;$b < 2;$b++){ 
for($c =0;$c < 4:$ctHH){ 
Srand = rand(1,4); 
echo "<img src='image/Srand.gif>": 
} 
; 中 
echo "<hr style='color:blue:>"; 
for($a = 0;$a < 2;$at+){ 
for($b= 0;$b < 2;$Sb+H{ 
for($c =0;$c < 4;$ctH){f 
Srand = rand(1,4); 
这 Srand (=2){ 
echo "<img src='image/Srand.gif>": 


break 3; 


> 


作 层 循环 
/从 层 循环 
/3 层 循环 
/111~4 随机 数字 
/输出 图 像 


作 层 循环 
/从 层 循环 
/3 层 循环 
/1~4 随机 数字 
/条件 语句 
/输出 图 像 


/结束 3 个 层级 的 循环 


(2) 将 该 文件 存储 于 \MR\02\074 文件 夹 中 ， 命 名 为 index php。 运 行 结果 如 图 2.47 所 示 。 


图 秘笈 心 法 


心 法 领悟 074: 灵活 运用 跳 转 语句 。 


跳 转 语句 一 定 要 灵活 运用 。 常 用 的 跳 转 语句 包括 break 语句 和 continue 语句 ，continue 语句 将 在 后 面 的 实例 


中 做 详细 介绍 。 


图 实例 说 明 


高 级 | 
趣味 指数 : 例会 例 侠 | 


在 循环 结构 中 ， 有 些 数 据 是 不 需要 的 ， 想 要 跳 过 这 些 代 码 向 下 执行 ， 这 时 候 就 需要 用 到 continue 语句 。 本 
实例 通过 continue 语句 实现 动态 改变 页 面 中 单元 格 的 背景 颜色 ,运行 结果 如 图 2.48 所 示 。 


动态 变色 


图 2.48 动态 改变 页 面 中 单元 格 的 背景 颜色 


图 关键 技术 


在 程序 执行 break 后 ， 程 序 将 跳出 循环 执行 流程 ， 而 开始 继续 执行 循环 体 的 后 续 语句 。continue 跳 转 语句 的 
作用 没有 break 那么 强大 ，continue 只 能 终止 本 次 循环 ， 而 进入 到 下 一 次 循环 中 。 在 执行 continue 语句 后 ， 程 序 
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将 结束 本 次 循环 的 执行 ， 并 开始 下 一 轮 循环 的 执行 操作 。continue 跳 转 语句 的 流程 控制 图 如 图 2.49 所 示 。 


图 2.49 continue 流程 控制 图 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 for 循环 定义 循环 变量 的 初始 值 为 0， 最 大 值 为 9， 并 且 每 执行 完 一 
次 循环 ， 循 环 变量 做 一 次 自 增 运算 。 然 后 ， 利 用 if0 语 句 定义 条 件 ， 当 循环 变量 小 于 等 于 5 时 ， 通 过 dechex 函 
数 获 取 6 个 十 六 进 制 随机 数 ， 否 则 终止 本 次 循环 。 最后， 将 取得 的 6 个 十 六 进 制 数 添加 到 <table> 标 签 的 bgcolor 
属性 中 ， 实 现 动态 变色 ， 其 代码 如 下 : 

<?php 


for($b=0;$b < 10:Sb+H){ /循环 语句 
这 Sb <= 5){ // 条 件 语句 
Srand = dechex(rand(0,15)): /取得 6 个 十 六 进 制 数 
jelse{ 
continue; // 不 满足 条 件 ， 重 新 执行 循环 
} 
} 
> 
<table height="55" bgcolor="#<?php echo $Srand;?>">// 设 置 背 景 颜色 
<tr><td width="156"></td> 
</tr></table> 
(2) 将 该 文件 存储 于 \MR\02\075 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.48 所 示 。 
图 秘笈 心 法 


心 法 领悟 075: continue 语句 的 妙用 。 
continue 语句 也 可 以 指定 跳 转 层级 数 。 


趣味 指 雪 :南座 催 页 


力 实例 说 明 


数学 中 有 这 样 一 道 题 : 取得 从 0~10 所 有 偶数 或 者 奇数 的 和 。 如 果 想 把 这 道 题 用 PHP 代码 表示 出 来 ， 则 需 
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要 使 用 跳 转 语句 continue 来 完成 。 本 实例 通过 跳 转 语句 continue 实现 屏蔽 偶数 次 的 数据 输出 , 运行 结果 如 图 2.50 
所 示 。 


EN| 
B#1=3|3 #9 [3*5=15|3 #7 =21| #0=27| 
#1 =5 [Sn 315 # 5 =25|5 ST =35|5 "oz45| 
Ps 1 = 3 301 5 =35[r #7 =49[7 * 97=63| 


1 9+* Hl rp dl * 7 -6 * 9 


2.50 ”屏蔽 偶数 次 的 数据 输出 


图 关键 技术 
本 实例 的 关键 点 是 continue 语句 的 灵活 运用 ， 详 细 说 明 请 参见 实例 075。 
设计 过 程 
创建 PHP 脚本 文件 。 首 先 通过 for0 循 环 语句 动态 输出 HTML 的 <tr> 标 签 和 数据 ,并且 当 循环 变量 为 偶数 时 


终止 本 次 循环 。 然 后 ， 利 用 相同 的 方法 动态 输出 HTML 的 <td> 标 签 和 数据 。 最 后 ， 在 页 面 中 输出 如 图 2.50 所 示 
的 表格 ， 其 代码 如 下 : 


for($a= 1;$a < 10:$at+){ 作 层 循环 
if($a %2 =— 0){ /如 果 为 偶数 则 回 到 本 循环 开始 位 置 
continue; 
} 
echo "<tr>"; 
for($b= 1;$b < 10:Sb+H){ 人 2 层 循环 
if($b %2 :=0){ /如 果 为 偶数 
echo "<td>"; 
echo "$a * Sb =".SarSb: /| 输出 结果 
echo “</td>"; 
jelsef 
continue; / 回 到 本 循环 的 开始 位 置 
} 
} 
echo "</tr>' 
} 


图 秘笈 心 法 


心 法 领悟 076: 求 余 运算 符 。 
利用 “%” 运 算 符 可 取得 两 个 数 的 余数 ， 本 实例 通过 此 运算 符 判断 是 否 为 偶数 ， 如 果 想 要 判断 是 否 为 奇数 
只 需 将 条 件 设 定 为 不 等 于 1 即 可 。 


高 级 | 
趣味 指数 : 食 食 食 食 : 


图 实例 说 明 
本 实例 通过 continue 语句 实现 跳 过 数据 输出 中 指定 的 记录 ， 运 行 结果 如 图 2.51 所 示 。 
图 关键 技术 


本 实例 应 用 continue 语句 跳 过 指定 的 循环 ， 输 出 指定 循环 以 外 的 数据 。 


I 
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0、PHP 典 型 模块 。 。 痢 
1、PHP 开 发 实战 宝 


2、JAVA 开 发 实战 宝 
国 PHP 网 络 编程 自学 手 是 


葡 入 委 承 过 记录 的 编号 
《PHP 典 型 模块 》《JAVA 开 发 实战 宝典 》 《PHP 网 络 编程 自学 手册 六 
2.51 ” 跳 过 数据 输出 中 指定 的 记录 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 一 个 数组 来 存储 数据 。 然 后 ， 定 义 下 拉 列 表 ， 其 中 下 拉 列 表 的 值 由 
PHP 代码 动态 添加 ， 当 输入 跳 过 记录 的 编号 并 单 击 “ 跳 过 ”按钮 时 ， 利 用 continue 语句 ， 输 出 不 包含 指定 数据 
的 其 他 数据 ， 其 代码 如 下 : 

<?php 

/定义 数组 

$array = array("PHP 典型 模块 ""PHP 开发 实战 宝典 ","JAVA 开发 实战 宝典 ","PHP 网 络 编程 自学 手册 "); 

全 

<form action="" method="post"> 

<textarea name="te" cols="20" rows="6">0、<?php echo $array[0]:;?> 1、 <?php echo Sarray[1];?> 2、<?php echo $array[2];?> 

3、<?php echo $array[3]:?> 

</textarea><br> 

<input type="text" name="text" value=" 输 入 要 跳 过 记录 的 编号 "size="20" onFocus="this.value=""> 

<input type="submit" name="subl" value=" 跳 过 "> 


</form> 
<?php 
这 $_POST[subl]){ /通过 POST 方式 传递 参数 
for($a = 0;$a < count($array):$a++){ // 循 环 数组 
这 Sa 一 $_POST[textD{ // 当 $a 等 于 文本 框 中 数据 时 回 到 循环 开始 位 置 
continue; 
jelsef 
echo' ('; 
echo $array[$a]: /输出 数组 元 素 
echo 》 ' 


> 
(2) 将 该 文件 存储 于 \MR\02\077 文件 夹 中 ， 命 名 为 mndex.php。 运 行 结果 如 图 2.51 所 示 。 
秘笈 心 法 


心 法 领悟 077: 在 HIML 中 插入 PHP 代码 。 
PHP 代码 可 以 插入 到 html 页 面 的 任何 位 置 ， 也 可 以 插入 到 html 的 任何 一 个 可 行 性 标签 之 中 。 


力 实例 说 明 


本 实例 利用 break 语句 实现 执行 指定 次 数 的 循环 ， 运 行 结 果 如 图 2.52 所 示 。 
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7 


已 经 输出 } 次 循环 
已 经 输出 2 次 循环 
己 经 输出 3 次 循环 
已 经 输出 4 次 循环 


已 经 输出 5 次 循环 
已 经 输出 6 次 循环 
已 经 输出 7 次 循环 


图 2.52 执行 指定 次 数 的 循环 


图 关键 技术 
本 实例 利用 break 语句 可 以 跳出 循环 并 终止 循环 的 特点 ， 控 制 循环 执行 的 次 数 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 当 单 击 “执行 ”按钮 时 ， 首 先 ， 定 义 for 循环 语句 ， 设 定 循环 变量 $a 的 初始 值 


为 0， 并 且 每 执行 一 次 循环 ，$a 做 一 次 自 增 运 算 。 然 后 ,通过 if0 语 句 定义 条 件 ， 如 果 $a 大 于 等 于 文本 框 中 输入 
的 数字 时 ， 跳 出 当前 循环 ， 否 则 输出 字符 串 ， 其 代码 如 下 : 


hp 
这 $_POST[subl]){ /通过 POST 方式 传递 参数 
for($a = 0;$a < 10000000000000:$a++jf /循环 
if($a >=$_POST[text){ /接收 文本 框 信息 判断 条 件 
break: /| 结束 循环 
jelsef /否则 循环 输出 


echo "已 经 输出 "($a+1)." 次 循环 <br>": 
} 
} 
} 


> 
(2) 将 该 文件 存储 于 \MR\02\078 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.52 所 示 。 
图 秘笈 心 法 


心 法 领悟 078: 流程 控制 语句 。 
流程 控制 语句 包括 条 件 控制 语句 、 循环 控制 语句 和 跳 转 控制 语句 ， 是 PHP 的 重要 组 成 部 分 也 是 PHP 程序 
员 必 须 重点 掌握 和 理解 的 内 容 。 


2.7 自 定义 函数 


在 开发 过 程 中 ， 经 常 需要 多 次 重复 某 种 操作 或 处 理 ， 如 数据 查询 、 字 符 操作 等 。 如 果 每 个 模块 都 要 重新 输 
入 一 次 代码 ， 不 仅 加 大 程序 员 的 工作 量 和 开发 时 间 ， 而 且 对 于 代码 的 后 期 维护 及 运算 效果 也 有 很 大 影响 。 使 用 
自 定义 函数 就 是 解决 该 问题 的 最 有 效 的 方法 。 


| 


趣味 指数 : 合 规 全 耸 | 


力 实例 说 明 
截取 字符 串 在 程序 设计 中 是 经 常 出 现 的 ， 例 如 ， 截 取 增 删改 查 SQL 语句 的 前 6 个 字符 进行 判断 ， 以 便 进行 
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增删 改 查 等 操作 。 本 实例 应 用 substr0 函 数 实现 用 自 定 义 函 数 截取 中 文字 符 串 ， 运 行 结果 如 图 2.53 所 示 。 


自 定 尽 函 数 截 到 中 文字 符 审 我 是 被 截取 的 部 分 


请 策 太 开始 茂 现 的 位 置 : SEX9s 。。。。。 
请 输入 截取 结束 的 位 置 : 拓 呈 gs 字 | 


定义 函数 截 


图 2.53 自 定义 函数 截取 中 文字 符 串 


图 关键 技术 


substr0 函 数 用 于 从 字符 串 中 按照 指定 位 置 截取 一 定 长 度 的 字符 ， 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 。 如 果 使 用 一 个 正 数 作为 子 串 的 起 点 来 调用 这 个 函数 ， 将 得 到 从 起 点 到 字符 串 结束 的 整个 字符 串 ; 
如 果 使 用 一 个 负数 作为 子 串 的 起 点 来 调用 , 将 得 到 原 字符 串 尾部 的 一 个 子 串 , 字符 个 数 等 于 给 定 负数 的 绝对 值 。 
Substr0 函 数 的 语法 如 下 : 

string substr ( string str, int start [, int length]); 

参数 str 用 来 指定 字符 串 对 象 ， 参数 start 用 来 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末 
尾 开始 截取 ; 参数 length 为 可 选项 ， 指 定 截取 字符 的 个 数 ， 如 果 其 为 负数 ， 则 表示 截取 到 倒数 第 length 个 字符 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 定 义 自 定义 函数 ， 当 单 击 “ 截 取 ” 按 钮 时 ， 利 用 substr0 函 数 对 指定 字符 串 进行 
截取 并 输出 截取 信息 ， 其 代码 如 下 : 


<?php 
function strO{ W 自 定义 函数 sr0 
这 $_POST[sub]){ /通过 POST 方式 传递 参数 
$a=" 自 定义 函数 截取 中 文字 符 串 我 是 被 截取 的 部 分 " ”// 定 义 字符 申 变 量 
Srs = substr($a,(2*$_POST['text]-2),(2+$_POST['text_11])); /截取 字符 串 
echo Srs; /输出 截取 结果 
} 
. 
st0; W 自 定义 函数 调用 
> 
(2) 将 该 文件 存储 于 \MR\02\079\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.53 所 示 。 
图 秘笈 心 法 


心 法 领悟 079: substr0 函 数 的 特点 。 
substrO 函 数 支 持 从 右 侧 取 值 ， 例 如 : 
<?php 


$a = abcdef /定义 字符 串 
Srs = substr($a,-2,1); /从 右 侧 取 值 
echo S$rs; /和 输出 截取 结果 


?> 
经 正 浏 览 器 运行 ， 显 示 结 果 为 “e”。 


高 级 | 


实例 080 趣味 指数 : 耸 亢 商 帘 | 


力 实例 说 明 


本 实例 通过 字符 串 截 取 函 数 和 自 定义 函数 实现 公告 标题 的 截取 ， 运 行 结果 如 图 2.54 所 示 。 
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FY oh 
CC, [一 ] 
甫 二 全 村 本 开交 葛 十 王 关 
3 和 
村 
| 
图 2.54 公告 标题 的 截取 


图 关键 技术 


自 定义 函数 ， 顾 名 思 义 是 由 用 户 自行 定义 并 完成 指定 功能 的 函数 。 自 定义 函数 的 产生 是 由 于 程序 员 在 进行 
日 常 开发 时 ， 使 用 PHP 预定 义 的 函数 并 不 能 实现 理想 的 功能 。 程 序 员 迫 切 希望 能 够 根据 自己 程序 的 实际 情况 自 
行 定义 完成 指定 功能 的 函数 。 创 建 函 数 的 基本 语法 格式 为 : 
function function name ([$arg_1],[$arg 2], … ,[Sarg_nD){ 
fon_body: 
人 


参数 说 明 : 

function: 声明 自 定义 函数 时 必须 使 用 的 关键 字 。 

function_name: 创建 函数 的 名 称 ， 是 有 效 的 PHP 标识 符 。 函 数 名 称 是 唯一 的 ， 其 命名 遵守 与 变量 命名 相同 
的 规则 ， 只 是 不 能 以 “$” 开 头 。 

arg_1…arg_n: 是 外 界 传 递 给 函数 的 值 ， 可 有 可 无 ， 也 可 以 有 多 个 ， 数 量 根 据 需 要 而 定 ， 各 参数 用 逗号 “,” 
分 隔 。 参 数 的 类 型 不 必 指 定 ， 在 调用 函数 时 只 要 是 PHP 支持 的 类 型 都 可 以 使 用 。 

fun_body: 自 定义 函数 的 主体 ， 是 功能 实现 部 分 。 

return: 将 调用 的 代码 需要 的 值 返回 ， 并 结束 函数 的 运行 。 

在 本 实例 中 ， 定 义 自 定义 函数 st， 对 字符 串 进行 截取 操作 ， 其 语法 如 下 : 


function str($stn) { W/ 自 定义 函数 
$a = strlen($str); /计算 字符 串 长 度 
$b = substr($str,0,$a); 1/ 截取 字符 串 
echo $b: /输出 
|， 
力 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 定 义 数组 ， 当 单 击 “ 获 取 标题 ”按钮 时 ， 调 用 自 定义 函数 str 对 数组 中 元 素 进行 
截取 ， 并 输出 截取 后 的 标题 信息 ， 其 代码 如 下 : 


<?php 

Sarray = array(" 南 非 世 界 杯 开赛 第 十 五 天 "." 南 非 世 界 杯 正 进行 得 如 火 如 蔡 ， 头 号 种 子 队伍 巴西 驳 勇 善战 ， 取 得 了 良好 成 绩 。"); 
/定义 数组 
> 


‘<table border="1" bordercolor="#CCCCCC"cellspacing="0" width="290" height="251" align="center” background="2.jpg"> 
<tr><td width="208" align="center"> 
<b style="font-family:' 文 易 霹雳 体 ` font-size:18px: color:#0033CC"><?php echo $array[0]:?></b><br> 
<b style="font-family: 方 正 新 报 宋 简 体 ': font-size:14px: color#0033CC">&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:<?php echo 
Sarray[1]:?></b><br> 
<a href="index.php?sub= 获 取 " style="float:center"> 获 取 标题 </a> /定义 链接 
<td> 
</tr><tr><td align="center"><b style="color:#EF0000; font-family: 方 正 细 圆 繁体 "> 


这 S$_GET[sub] 一 "获取 "{ /通过 GET 方式 获取 参数 


Us 


> 
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/调用 自 定义 函数 


/W/ 自 定义 函数 

// 计 算 字 符 串 长 度 
/截取 字符 串 
/输出 


(2) 将 该 文件 存储 于 WMR\02\080\ 文 件 夹 下 ， 命 名 为 index .php。 运 行 结果 如 图 2.54 所 示 。 


图 秘笈 心 法 


心 法 领悟 080: 自 定义 函数 的 应 用 注意 事项 。 


自 定义 函数 的 名 称 是 不 区 分 大 小 写 的 ， 而 常量 和 变量 的 名 称 区 分 大 小 


实例 081 


图 实例 说 明 


发 论坛 程序 很 重要 的 一 点 是 转换 空格 符 和 回 车 符 ， 因 为 不 是 所 有 的 论坛 用 户 都 知道 HTML 标签 &nbsp; 和 


<br> 的 作用 ， 大 多 数 用 户 都 喜欢 用 空格 键 和 回 车 键 对 文本 进行 控制 ， 这 就 需要 程序 员 人 为 地 做 到 统一 。 本 实例 
容 的 简短 输出 ， 运 行 结果 如 图 2.55 所 示 。 


通过 自 定义 函数 定义 转换 方法 实现 论坛 内 


图 关键 技术 


育 而 坊 


标题 ，PHP 
内 容 ，PHP 编 程 你 好 PHP 编 程 谢谢 您 


图 2.55 论坛 内 容 的 简短 输出 


本 实例 通过 自 定义 函数 实现 对 字符 串 中 空格 等 和 回 车 符 的 转换 输出 ,在 自 定义 函数 中 应 用 的 是 preg_replaceO 


函数 。 自 定义 函数 的 语法 如 下 : 
function str(Sstr){ 


Sstr = preg_replace("/ /","&nbsp:",$str): 
Sstr = preg_replace("/cha(13)/"."<br>",$str): 


echo "内 容 : ".$str; 


图 设计 过 程 


// 自 定义 函数 
/替换 空格 

// 蔡 换 回 车 符 
/输出 


(1) 创建 PHP 脚本 文件 ， 通 过 自 定义 函数 定义 对 &nbsp; 和 回 车 进行 替换 ， 当 单 击 “ 提 交 ” 按 钮 时 ， 首 先 
对 文本 框 是 否 存在 内 容 进行 判断 ， 如 果 文本 框 内 容 不 为 空 ， 调 用 自 定义 函数 并 输出 文本 信息 ， 其 代码 如 下 : 


<?php 
function str(SstD{f 


Sstr = preg_replace("/ /"."&nbsp:;".$str): 


S$str = preg_replace("/cha(13)/","<br>",$str): 


echo "内 容 : ".$str; 


| 
这 $_ POST[sub]){ 


/如果 text 为 空 或 者 文本 域 和 下 拉 列 表 框 同时 为 空 
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W 自 定义 函数 
/替换 空格 
// 蔡 换 回 车 符 
/和 输出 


// 通 过 POST 方式 传 参 


第 2 章 PHP 基 础 


这 $ ] i 一 ”||(S_ POST[te] 一 ”)&& ($ POST[check] — D){ 


echo "<script>alert( 内 容 不 能 为 空 ):location_ href-'index.php'</script>": /输出 提示 
jelsef 
这 $_POST[select] = '1){ /当下 拉 列 表 值 不 等 于 1 时 
echo "标题 : "S_POSTtextl "<br>"; /输出 内 容 和 下 拉 列 表 内 容 
str($ POST[tel.$ POSTIcheck)): 
Jelse{ 
echo "标题 : "S_POSTtextl "<br>"; /否则 只 输出 文本 域内 容 
str($_POST[te]): 
} 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\081\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.55 所 示 。 
图 秘笈 心 法 
心 法 领悟 081: 对 于 实例 代码 的 重要 说 明 。 
上 例 代码 中 “$_POST[text] 一 "|| (($_POST[te] 一 "") && ($_POST[check] 一 1))” 是 存在 运算 符 优先 级 的 ， 


为 了 避免 发 生 错误 ， 笔 者 将 先进 行 的 运算 人 为 加 上 小 括号 。 


实例 说 明 

用 户 在 论坛 上 发 表 或 者 回复 留言 时 可 能 会 遇 到 这 种 情况 ， 单 击 “ 发 布 ”按钮 时 ， 系 统 提示 使 用 了 禁用 词语 ， 
禁止 发 布 。 这 是 论坛 的 开发 人 员 为 了 规范 论坛 而 采用 的 过 滤 字 符 串 的 手段 。 本 实例 通过 自 定义 函数 实现 过 滤 字 
符 串 ， 运 行 结 果 如 图 2.56 所 示 。 


2.56” 自 定义 函数 过 滤 字 符 串 


力 关键 技术 


本 实例 编写 自 定义 函数 str0， 对 字符 串 进行 过 滤 ， 如 果 出 现 指 定 的 关键 词 ， 则 给 出 提示 信息 ， 并 终止 程序 
执行 。 自 定义 函数 sr0 的 语法 如 下 : 


function str($str) { 
Sarray =array( 图 书 ', 明 日 科技 ,软件 ,编程 词典 ,编程 ,词典 ): // 定 义 数组 
Srepstr = implode($array): /其 组 转换 成 字符 串 
if(preg_match("/$str/", Srepstr){ // 正 则 表达 式 验证 字符 串 
echo "<script>alert( 您 使 用 了 禁用 词语 ， 请 重新 填写 "):location href="'index.php'</script>"; 
jelsef{ 
echo "内 容 为 : "$str; /输出 数据 


117 


PHP 开发 实战 1200 例 (第 I 卷 ) 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 自 定义 函数 ， 将 禁用 词语 保存 在 数组 中 ， 并 通过 字符 串 函 数 拆 分 数组 ， 
利用 正则 表达 式 函 数 对 禁用 词语 进行 屏蔽 。 当 单 击 “ 提 交 ” 按 钮 时 ， 调 用 自 定义 函数 对 提交 内 容 进 行 过 滤 ， 并 
输出 提示 信息 ， 其 代码 如 下 : 


<?php 
fanction str(SstD{ 
$array = array(' 图 书 ', 明 日 科技 ", 软 件 ', 编 程 词典 ,编程 词典); /定义 数组 
Srepstr = implode($array); / 粕 组 转换 成 字符 串 
if(preg_match("/$str/",$repstr)) { /正则 表达 式 验证 字符 串 
echo "<script>alert( 您 使 用 了 禁用 词语 ， 请 重新 填写 ):location href-index.php'</script>": 
{ 
echo "内 容 为 : ".$str; /输出 数据 
} 
这 $ POST[sub]){ 
str($_POST[te]); // 调 用 自 定义 函数 
(2) 将 该 文件 存储 于 \MR\02\082\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.56 所 示 。 
图 秘笈 心 法 


心 法 领悟 082: 过 滤 程序 。 
本 实例 只 是 简单 地 介绍 了 字符 串 过 滤 的 原理 , 真正 的 过 滤 程 序 由 于 数据 量 较 大 需要 将 数据 存储 在 数据 库 中 。 
如 果 读者 感 兴趣 ， 可 以 将 其 与 数据 库 中 的 数据 结合 使 用 。 


28 字 符 串 


在 许多 Web 编程 中 ， 字 符 串 总 是 会 被 大 量 地 生成 和 处 理 。 正 确 地 使 用 和 处 理 字符 串 ， 对 于 PHP 程序 员 来 
说 越 来 越 重要 。 


et 


高 级 | 
趣味 指数 : 会 傅 傅 会 | 


图 实例 说 明 


由 于 各 个 用 户 所 使 用 的 输入 法 不 同 或 者 个 人 习惯 的 关系 ， 有 可 能 不 经 意 间 多 输入 了 空格 或 者 特殊 字符 ， 造 
成 网 站 内 容 的 输出 不 美观 。 本 实例 通过 ltrim0 和 rtrim0 函 数 实现 去 除 字符 串 的 空白 和 特殊 字符 ， 运 行 结果 如 
图 2.57 所 示 。 


去 除 字符 串 空白 和 特殊 字符 前 ; (CQ_G 你 好 YPHP 范 例 @_@;) 
去 除 字符 串 空白 和 特殊 字符 后 : 你 好 PHP 范 例 


图 2.57 去 除 字符 串 空白 和 特殊 字符 


图 关键 技术 


(1) ltrim0 函 数 
使 用 lrim0 函 数 默 认 情 况 下 去 除 左 边 空格 ， 去 除 特殊 字符 的 参数 可 选 。 


118 


第 2 章 PHP 基 础 
string ltrim ( string str [, string charlist): 
参数 说 明 : 
string str: 源 字符 串 信息 。 
string charlist: 可 选 参数 ， 特 殊 字 符 。 
(2) rtrim0 函 数 


使 用 rtim0 函 数 默 认 情 况 下 去 除 右 边 空 格 ， 去 除 特殊 字符 的 参数 可 选 。 
string rtrim ( string str [, string charlist]); 

参数 说 明 : 

string str: 源 字 符 串 信息 。 

string charlist: 可 选 参数 ， 特 殊 字符 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 定 义 字 符 串 变量 $a， 分 别 通过 lrim0 和 rtrim0 函 数 去 除 两 边 的 空格 和 特殊 字符 并 
显示 结果 ， 其 代码 如 下 : 


<?php 
Sa="C@ S 你 好 ! PHP 范例 @_@:)“ /声明 一 个 带 空格 和 特殊 字符 的 字符 串 变 量 
$b = ltrim($a): /去 除 变 量 左 边 的 空格 
Sc= iisbeC@ @"); /去 除 变 量 左边 的 特殊 字符 
Sd = rtrim($c); // 去 除 变量 右边 的 空格 
$e =rtim($d,"@_@)"); // 去 除 变量 右边 的 特殊 字符 
echo "去 除 字符 帅 空白 和 特殊 字符 前 "$a"<br>" 
echo "去 除 字符 串 空白 和 特殊 字符 后 : "Se; /输出 最 后 结果 
> 
(2) 将 该 文件 存储 于 \MR\02\083\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.57 所 示 。 
图 秘笈 心 法 


心 法 领悟 083: 使 用 ltrim0 函 数 和 rtrim0) 函 数 的 相关 说 明 。 
在 使 用 这 两 个 函数 时 ， 默 认 情 况 下 是 只 去 除 左边 或 者 右边 的 空格 ， 想 要 去 除 特殊 字符 需要 在 函数 里 注 明 。 


高 级 | 
趣味 指数 : aetotek 


图 实例 说 明 


论坛 帖子 中 的 单 引号 和 双 引 号 在 未 经 转 义 的 情况 下 输出 会 出 现 问题 , 特别 是 在 输出 SQL 语句 时 。 本 实例 通 
过 addslashes() 函 数 来 实现 转 义 字符 串 ， 运 行 结果 如 图 2.58 所 示 。 


趟 经 转 头 的 字符 帅 PHE 数 据 库 插入 语 梧 全 INSERTDINID 1B160G 3 SAL UPS (YY Ya 
经 转 义 后 的 字符 帅 。 PHP 数 据 库 插入 语 向 :INSERT INID table ( 3a HE VALUES(Wi, 于 压 J ) 


图 2.58 转 义 字符 串 


图 关键 技术 


本 实例 主要 是 通过 addslashes0 函 数 对 指定 的 SQL 语句 进行 自动 转 义 。addslashes 函数 可 以 转 义 单 引号 、 双 
引号 、 反 斜 杠 、NULL 字符 ， 主 要 用 于 SQL 语句 ， 对 部 分 字符 进行 转 义 ， 其 语法 如 下 : 

string addslashes ( string str): 

参数 说 明 : 

string str: SQL 语句 。 
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图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 首 先 ， 定 义 插入 型 SQL 语句 。 然 后 ， 将 SQL 语句 通过 addslashes0 函 数 转 义 并 
显示 转 义 结果 ， 其 代码 如 下 : 


<?php 
$str = "INSERT INTO db(id,user.,pwd,last_date)VALUES('1'.'yang’,*****#''2010-06-03)"; /声明 一 个 字符 串 变量 
echo "未 经 转 义 的 字符 串 : "Sstr."<br>"; /未 经 转 义 
echo "经 转 义 后 的 字符 串 : ".addslashes($str); 1/ 经 转 义 
> 
(2) 将 该 文件 存储 于 \MR\02\08 人 4 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.58 所 示 。 
图 秘笈 心 法 


心 法 领悟 084: addslashes0 函 数 在 程序 中 的 应 用 。 
addslashes0 〇 函数 主要 用 于 数据 库 SQL 语句 的 转 义 ， 当 数据 要 插入 到 数据 库 之 前 ， 有 必要 应 用 addslashes() 
函数 进行 字符 串 转 义 ， 以 免 特殊 字符 未 经 转 义 在 插入 数据 库 时 出 现 错误 。 


实例 085 


图 实例 说 明 


既然 可 以 将 帖子 内 容 进 行 转 义 ,当然 也 可 以 将 帖子 内 容 进 行 还 原 。 本 实例 通过 stripslashes0 函 数 来 实现 还 原 
字符 串 ， 运 行 结果 如 图 2.59 所 示 。 


二 还 原 的 字符 市 PHE 雪 据 库 括 入 二 合计 INStRIOINiD ta RALUPSONN ,Gene\ 册 
经 还 原 后 的 宇 符 朱 A PHE 数 据 库 插入 语句 INSERU IJNID table (1d ,name YALUPS( YY Yanelline’) 


图 2.59 还 原 字符 串 


图 关键 技术 


本 实例 运用 stripslashes0 函 数 ， 将 addslashes0 函 数 转 义 的 字符 串 进行 还 原 ， 其 语法 如 下 : 
string stripslashes ( string str); 

参数 说 明 : 

string str: SQL 语句 。 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 , 首先 , 定义 数据 库 插入 语句 的 字符 串 变 量 。 然后, 将 字符 串 变 量 通过 stripslashesO 
函数 还 原 并 显示 运行 结果 ， 其 代码 如 下 : 


<?php 
$str = "INSERT INTO db(id.user.pwdlast_datej)VALUES(C1',yang',+++++#2010-06-03)": /声明 一 个 字符 串 变量 
echo "未 经 还 原 的 字符 串 : ".$str."<br>"; /未 经 还 原 字符 串 输出 
echo "经 还 原 后 的 字符 串 : ".stripslashes($stn)."<br>": // 经 还 原 后 的 字符 串 输出 


> 
(2) 将 该 文件 存储 于 \MR\02\085\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.59 所 示 。 
图 秘笈 心 法 
心 法 领悟 085: stripslashesO 函 数 的 应 用 。 
stripslashes() 函 数 主要 用 于 数据 库 SQL 语句 的 还 原 输出 。 
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i Wai 
同 
实例 086 趣味 指数 : 会 售 傅 请 : 
图 实例 说 明 


本 实例 通过 substr0 函 数 实现 截取 论坛 标题 ， 运 行 结果 如 图 2.60 所 示 。 


2.60 ”截取 论坛 标题 


图 关键 技术 


substrO 函 数 用 于 从 字符 串 中 按照 指定 位 置 截取 一 定 长 度 的 字符 。 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 ， 如 果 使 用 一 个 正 数 作为 子 串 起 点 来 调用 这 个 函数 ， 将 得 到 从 起 点 到 字符 串 结束 的 整个 字符 串 ， 如 
果 使 用 一 个 负数 作为 子 串 起 点 来 调用 ， 将 得 到 原 字符 串 尾部 的 一 个 子 串 ， 字 符 个 数 等 于 给 定 负 数 的 绝对 值 ， 其 
语法 如 下 : 

string substr ( string str, int start [, int length]) 

参数 str 用 来 指定 字符 串 对 象 ， 参 数 start 用 来 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末 
尾 开 始 截 取 ;， 参数 length 为 可 选项 ， 指 定 截取 字符 的 个 数 ， 如 果 其 为 负数 ， 则 表示 取 到 倒数 第 length 个 字符 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 变量 $a 并 将 网 页 标题 赋 给 $a。 然 后 ， 通 过 substr0 函 数 对 字符 串 $a 进 
行 截取 ， 并 输出 截取 内 容 ， 其 代码 如 下 

<?php 


S$b = "截取 论坛 标题 " // 设 定 字符 串 
$a="<title>$b</title>"; // 设 定 网 页 标题 
echo Sa; /输出 字符 串 
echo "本 论坛 标题 : ".Sb."<br>": /输出 论坛 标题 
$b = substr($b,0,12); /截取 论坛 标题 
echo "截取 的 字符 串 :".$b; /输出 截取 内 容 
Wn 
(2) 将 该 文件 存储 于 \MR\02\053\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.60 所 示 。 
图 秘笈 心 法 


心 法 领悟 086: substr0 函 数 应 用 的 注意 事项 。 
substrO 函 数 的 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 1 个 字符 表示 为 0。 本 函数 在 截取 
中 文字 符 串 时 ， 可 能 会 出 现 乱 码 ， 所 以 建议 在 对 中 文字 符 串 进行 截取 时 应 用 mb_substr0 函 数 。 


图 实例 说 明 
字符 串 的 分 割 、 合 成 对 于 程序 员 来 说 是 十 分 重要 的 ， 在 应 用 方面 也 十 分 广泛 。 例 如 ， 在 遍历 数据 库 查 找 匹 
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配 项 时 就 会 用 到 合成 函数 ， 而 购物 车 程序 一 般 会 用 到 分 割 函数 。 本 实例 通过 explodeO 函 数 和 implode0 函 数 实现 
分 割 、 合 成 字符 串 ， 运 行 结果 如 图 2.61 所 示 。 


原 宇 符 帅 ， 你 好 PHEN 很 高 兴 认 识 你 ， 
经 分 割 后 的 数组 为 : Si [0] = 你 好 PHP 区 0] = 六 很 高 兴 认 识 你 ,9》 


合成 后 的 字符 串 》 你 好 PEF 很 高 兴 认识 你 。 


图 2.61 分割、 合成 字符 串 


力 关键 技术 


字符 串 的 分 割 与 合成 应 用 的 是 explode0 函 数 和 implode0 函 数 。 

(1) explode0 函 数 

explode0 函 数 按照 指定 的 规则 对 一 个 字符 串 进 行 分 割 ， 返 回 值 为 数组 ， 其 语法 如 下 : 

array explode ( string separator, string string [, int limit]); 

参数 string string 表示 分 割 条 件 ，separator 表示 指定 的 分 隔 符 ，int limit 表示 指定 生成 数组 的 最 大 值 。 

(2) implode0 函 数 

implode0 函 数 与 explodeO 函 数 配 合 使 用 ， 将 数组 的 内 容 组 合成 一 个 字符 串 ， 其 语法 如 下 : 

string implode ( string glue, array pieces); 

参数 glue 是 字符 串 类 型 ， 指 定 分 隔 符 ， 参 数 pieces 是 数组 类 型 ， 指 定 要 被 合并 的 数组 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首先, 定义 字符 串 变 量 , 将 字符 串 内 容 用 指定 的 分 隔 符 分 隔 。 然后 , 利用 explodeO 
函数 ， 将 字符 串 变量 按照 规定 的 分 隔 符 分 割 ， 并 保存 在 数组 变量 gexplode 中 。 最 后 ， 分 别 利用 prinr_rO 函 数 和 
implodeO 函 数 输出 数组 和 字符 串 ， 其 代码 如 下 : 


<?php 
S$str= "你 好 PHP 很 高 兴 认识 你 。"; // 定 义 字符 串 
Sexplode = explode(" ",$str); // 分 割 字 符 串 
echo " 原 字符 串 : ".$str."<br>"; /输出 原 字符 串 
echo "经 分 割 后 的 数组 为 :"; 
Print_1(Sexplode); // 打 印 分 割 后 的 数组 
echo "<br> 合 成 后 的 字符 串 : "; 
echo implode(Sexplode); // 将 数组 合成 为 字符 串 


> 
(2) 将 该 文件 存储 于 \MR\02\087\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.61 所 示 。 
图 秘笈 心 法 


心 法 领悟 087: explode0 函 数 和 implode0 函 数 哪个 应 用 更 广泛 ? 
二 者 相 比 ，implode0 函 数 应 用 相对 广泛 ， 所 有 的 数组 变量 ， 都 可 以 用 它 进行 合成 。 


高 级 
趣味 指数 : 会 会 家 窗 : 


国 实例 说 明 
关键 字 描 红 技术 广泛 应 用 于 站 内 搜索 或 者 高 级 搜索 中 ， 是 一 项 很 常用 的 技术 。 本 实例 通过 函数 str_replaceO 
实现 查询 关键 字 描 红 ， 和 运行 结果 如 图 2.62 所 示 。 
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被 搜索 的 交 本 PHP 作为 全 球 扣 普及 、 应 用 总 广泛 的 互联 网 开发 语言 之 一 ,从 1994 
年 证 生 至 今 已 被 2000 宛 万 个 动态 网 站 采用 . 全 球 知 名 互联 网 公司 Google、Yahoo、 
eBay 和 中 国 知名 网 站 新 滚 、 百 度 、 阿 至 巴 巴 等 风采 赴 PHP 层 术 ! 


9 el 


PHP 作 为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 证 生 择 今 已 被 
2000 务 万 个 动态 网 站 于 用 ， 全球 知名 互联 网 公司 Go0gle。Yahoo、eBay 和 中 国 知 儿 网 
站 新 浪 、 百 度 /阿里 巴巴 等 均 采 用 PHP 技 术 ， 


图 2.62 查询 关键 字 描 红 


图 关键 技术 
str_ replace 0 函数 可 用 于 执行 字符 串 替 换 操作 ， 其 语法 如 下 


mixed str_ replace ( mixed search mixed replace. mixed subject [ int &count ) 
参数 说 明 : 

search: 必要 参数 ， 指 定 需 要 查找 的 字符 串 。 

replace: 必要 参数 ， 指 定 蔡 换 的 值 。 

subject: 必要 参数 ， 指 定 查找 范围 。 

count: 可 选 参数 ， 获 取 执 行 替 换 的 数量 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 将 通过 POST 方式 接收 到 数据 ， 首 先 对 数据 进行 描 红 
处 理 ， 然 后 ， 应 用 str_replaceO 函 数 对 指定 字符 串 信息 的 指定 内 容 进行 蔡 换 ， 其 代码 如 下 : 


<?php 
if($_POST[sub){ 
$a = "<b style='color:red;font-size:18px:>".$_POST[text]."</b>"; 1/ 对 提交 的 关键 字 进 行 描 红 
echo str_replace("$_POST[text]",$a,S$str); // 完 成 字符 串 的 替换 操作 
1 
> 


(2) 将 该 文件 存储 于 \MR\02\088\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.62 所 示 。 
图 秘笈 心 法 


心 法 领悟 088: 更 多 实现 关键 字 描 红 的 函数 。 
不 仅 可 以 通过 str_replace0 函 数 实现 关键 字 的 描 红 操作 ， 还 可 以 通过 str_ireplace0 函 数 实现 对 关键 字 的 描 红 
功能 ， 并 且 该 函数 不 区 分 大 小 写 。 


实例 089 


图 实例 说 明 
在 站 内 搜索 中 ， 往 往 要 求 列 出 符合 条 件 的 关键 字 有 多 少 个 。 本 实例 通过 字符 串 函 数 substr_countO 统 计 查 询 
关键 字 的 出 现 次 数 ， 运 行 结果 如 图 2.63 所 示 。 


被 搜索 的 文本 :PHP 作为 全 球 最 普及 、 应 用 景 广泛 的 互联 网 开发 语言 之 一 ， 从 V34 年 泛 生 至 今 已 被 2000 多 万 个 动 杰 网 站 采用 ， 全 奈 知名 互联 
Re Yshbo，eBay 和 中 国 知名 网 站 新 禄 i 百度、 同 旦 蔬 已 等 掏 杀 用 PIP 技术 


[HP 作为 全 球 景 兰 及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 “从 1984 年 诞生 至 今 己 被 2060 才 万 个 动态 网 站 条 用 ， 全 秆 知 省 五 联网 盆 司 coogle: 
[Tahoo、eBay 和 中 屋 和 站 网 站 者 良 、 百度 、 阿 里 巴巴 等 沟 对 十 PRE 扶 术 1 
其 键 字 出 现 2 次 。 


图 2.63 统计 查询 关键 字 的 出 现 次 数 
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力 关键 技术 


本 实例 通过 substr_countO 函 数 检索 字符 串 子 串 的 出 现 次 数 。substr_countO 函 数 的 语法 如 下 : 

int substr_count ( string haystack, string needle ) 

参数 说 明 : 

string haystack: 源 字符 串 。 

string needle: 字符 串 子 串 。 
图 设计 过 程 

(1) 创 建 PHP 脚本 文件 , 首先 , 定义 字符 串 变 量 ,编写 <form> 表 单 。 当 单 击 “ 搜 索 ” 按 钮 时 ,利用 substr_countO 

函数 输出 指定 字符 串 子 串 的 出 现 次 数 ， 其 代码 如 下 : 

0 echo "<a style='font-size:20px: color#000000> 被 搜索 的 文本 :</a>": /定义 字符 串 输出 


Sstr = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知名 
互联 网 公司 Google、Yahoo、eBay 和 中 国 知名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采用 PHP 技术 !"; 


echo $str."<br>"; 
2 
<form action ="" method="post"> / 语 单 
关键 字 : <input type="text" name="text"><input type="submit" name="sub" value 一 "搜索 "> 
</form> 
</body> 
</html> 
hp 
if($_POST[sub]){ /通过 POST 方式 传递 参数 
$a = "<b style='color:red:font-size: 18px;>".$_POST[text]."</b>"; // 营 换 后 的 字符 串 
echo str_replace("$_POST[text]",$a,$str)."<br>"; // 营 换 字符 串 
/统计 关键 字 出 现 次 数 
echo "关键 字 出 现 <b style='color:red;font-size:22px;>".substr_count($str,$_POST[text])."</b> 次 。"; 
让 
> 


(2) 将 该 文件 存储 于 \MR\02\089\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.63 所 示 。 
图 秘笈 心 法 


心 法 领悟 089: substr_count0 函 数 的 实现 原理 。 
substr_countO 函 数 是 一 种 类 似 全 文 检索 的 函数 ， 其 原理 是 检索 查找 匹配 的 字符 串 ， 返 回 匹 配 次 数 。 


图 实例 说 明 


文件 上 传 功能 几乎 是 所 有 网 站 所 必 备 的 ， 然 而 文件 上 传 对 于 服务 器 来 说 是 具有 很 大 风险 的 ， 因 此 应 该 对 文 
件 大 小 、 文 件 类 型 进行 限制 。 本 实例 通过 字符 串 函 数 strrev0 获 取 上 传 文件 的 后 级 ， 运 行 结果 如 图 2.64 所 示 。 
yDocunents\ 苍 出 大 [I 开 -]] 上传 ] 


.doe 


图 2.64 获取 上 传 文件 的 后 级 


图 关键 技术 
PHP 中 字符 串 的 逆序 输出 可 以 通过 循环 实现 ， 但 最 简单 的 方式 是 通过 函数 strev0 实 现 。stmrev0 函 数 可 将 字 
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符 串 反 转 ， 其 语法 如 下 : 

string strrev ( string string ); 

参数 说 明 : 

string string: 需要 反 转 的 字符 串 。 

在 本 实例 中 ， 通 过 strev0 函 数 对 上 传 文件 的 名 称 进行 反 转 输出 ， 并 通过 explode0 函 数 以 “.” 为 分 隔 符 ， 对 
文件 名 称 进行 分 割 ， 然 后 再 次 应 用 strrev0 函 数 对 数组 中 的 第 一 个 元 素 值 进行 返回 输出 ， 获 取 到 的 就 是 上 传 文件 
的 后 级 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 首 先 ， 利 用 POST 方法 接收 文本 框 中 的 信息 。 然 后 ， 


利用 反 转 函数 将 文本 框 信息 数据 进行 反 转 ， 并 利用 字符 串 拆 分 函数 以 “.” 进 行 分 割 ， 然 后 将 分 割 结果 保存 在 数 
组 中 。 最 后 ， 将 指定 数据 再 次 反 转 取得 并 输出 上 传 文件 的 后 缀 名 称 ， 其 代码 如 下 : 
<?php 


这 $_ POST[sub]){ 1/ 通过 post 方 式 传递 参数 
$a = strrev($_POST[text]); / 反 转 字符 串 
$b= explode(".",$a); /以 点 号 分 割 
Sc = stmev(gb[0]); / 反 转 字符 串 
echo "文件 后 级 为 :.Sc": /输出 文件 后 级 

} 

> 
(2) 将 该 文件 存储 于 \MR\02\090\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.64 所 示 。 
图 秘笈 心 法 


心 法 领悟 090: 知识 扩展 。 
利用 strev0 函 数 检索 字符 串 相对 较 麻烦 ， 可 以 使 用 正则 表达 式 函 数 preg_match0 来 完成 该 功能 。 


大 小 写 


et 


高 级 
直 叶 指 煞 ， 帘 全 宣 宙 | 


力 实例 说 明 


统一 上 传 文件 名 称 的 大 小 写 是 十 分 必要 的 。 例 如 上 传 图 片 文件 img.jpg 和 Img.jpg， 如 果 文 件 名 称 未 经 大 小 
写 统一 ， 则 上 传 时 可 能 不 会 出 现 缆 盖 提 示 。 本 实例 通过 字符 串 函数 strtoupper0 和 strtolowerO 实 现 统一 上 传 文件 
名 称 的 大 小 号， 运行 结果 如 图 2.65 所 示 。 
关键 字 计 F:\xanpp xanpp Vlicens [到 J] 上传] 


度 件 名 称 白 动 转换 为 大 写 : 1. JPG 
度 件 名 称 自 动 转换 为 小 写 : 1. jpg 


2.65 ”统一 上 传 文件 名 称 的 大 小 写 


图 关键 技术 


实现 字符 串 的 大 小 写 转换 ， 主 要 通过 strtolower0 和 strtoupper0 函 数 实现 。 
(1) strtolower0 函 数 

使 用 该 函数 转换 为 小 写 。 

TT 
(2) strtoupper0) 函 数 

使 用 该 函数 转换 为 大 写 。 
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string strtoupper ( string string ) 
参数 string 为 需要 转换 的 字符 串 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 , 当 单 击 “ 上 传 ”按钮 时 , 分 别 利 用 转换 小 写 和 大 写 的 函数 strtolower0 和 strtoupper() 
将 接收 到 的 文本 框 的 信息 进行 对 应 的 大 小 写 转换 ， 并 输出 转换 结果 ， 其 代码 如 下 : 


hp 
这 $_POST[sub]){ /通过 POST 方式 传 参 
$a = strtoupper($_POST[text]); /| 转换 为 大 写 
echo "文件 名 称 自动 转换 为 大 写 :".$a."<br>"; /输出 
Sb = strtolower($_POST[text]); /转换 为 小 写 
echo "文件 名 称 自 动 转换 为 小 写 : ".$b; /输出 
?> 


(2) 将 该 文件 存储 于 \MR\02\091\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.65 所 示 。 
图 秘笈 心 法 
心 法 领悟 091: strtolower0 和 strtoupper0 函 数 的 应 用 范围 。 


在 电子 商务 类 网 站 的 后 台 商 品 添加 页 面 中 ， 为 了 使 商品 的 型 号 以 统一 的 规格 显示 ， 经 常会 使 用 大 小 写 转换 
函数 ， 所 以 掌握 这 两 个 函数 是 很 有 必要 的 。 


OO 及 ”| 
: 


实例 092 趣味 指数 : i 


力 实例 说 明 
在 论坛 文本 框 里 使 用 HTML 标签 是 存在 作用 效果 的 ， 但 是 对 于 论坛 管理 员 来 说 是 不 希望 看 到 的 ， 因 为 它 会 
给 服务 器 造成 压力 。 本 实例 通过 htmlentitiesO 函 数 实现 字符 串 与 HTML 的 转换 ， 运 行 结果 如 图 2.66 所 示 。 

没有 进行 转换 


RS :20in.0503 


进行 了 转换 

<table border = 由 ><tr><td> 标 题 ; 经 济 半 小 时 </td><td> 修 改 时 间 : 2010-06: 
03<Jtd> </tr><tr><td> 内 容 : 经 济 半 小 时 关 了 解 中 国 经 济 最 好 的 节目 

</td> </tr> </table> 


图 2.66 字符 串 与 HTML 转换 


图 关键 技术 


PHP 中 使 HTML 代码 格式 化 输出 可 以 使 用 函数 htmllentities0 〇 实现。htmllentities0 函 数 的 语法 如 下 : 
string htmlentities(string string,[int quote_style].[string charset]); 

参数 说 明 : 

string string : 需要 格式 化 输出 的 html 代码 。 

int quote style: 可 选 参数 ， 一 般 设 置 为 ENT_ QUOTES。 

string charset: 设置 编码 格式 。 
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图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 首 先 ， 定 义 字符 串 变量 ， 变 量 内 容 为 一 段 HTML 标签 (创建 表格 的 代码 ) 。 然 
后 ， 利 用 htmllentitiesO 函 数 将 字符 串 变 量 进行 转换 并 输出 转换 结果 ， 其 代码 如 下 : 
<?php 


echo "<h2> 没 有 进行 转换 </h2> 
$str = "<table border = 经 济 半 小 时 </td><td> 修 改 时 间 : 2010-06-03</td></tr><tr><td> 内 容 : 经 济 半 小 时 ， 了 解 中 国 经 济 最 好 的 


节目 <ftd></tr></table>"; // 定 义 HTML 格式 
echo $str /输出 字符 串 
echo "<h2> 进 行 了 转换 </h2>"; 
echo htmlentities($str, ENT_QUOTES,"GB2312")."<br>"; /| 转换 HIML 


> 


(2) 将 该 文件 存储 于 \MR\02\092\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.66 所 示 。 
图 秘笈 心 法 


心 法 领悟 092: 使 用 格式 化 函数 输出 的 优点 。 
格式 化 输出 HTML 可 以 直接 将 提交 的 源码 输出 并 确保 源码 不 被 解析 ， 从 而 可 以 确保 直接 在 页 面 中 输出 
HTML 标签 ， 而 不 被 解析 。 


实例 说 明 
统计 字符 串 长 度 一 般 是 为 了 给 其 他 函数 的 应 用 做 好 铺垫 。 本 实例 通过 stlen0 函 数 获取 帖子 标题 的 长 度 ， 运 


行 结果 如 图 2.67 所 示 。 


标题 :| PHP 织 得 字典- 
内 容 : A 

发 布 
标题 长 度 为 11 个 字 节 、 


图 2.67 统计 帖子 标题 的 长 度 


图 关键 技术 
strlen0 函 数 用 于 获取 字符 串 的 长 度 ， 其 语法 如 下 : 


int strlen ( string str); 
参数 说 明 : 
str: 指定 字符 串 。 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 发 布 ”按钮 时 ， 利 用 strlen0 函 数 获 取 通 过 POST 方式 接收 到 的 数据 长 
度 ， 其 代码 如 下 : 
<?php 
这 $_POST[sub]){ /通过 POST 方式 传 参 


echo "标题 长 度 为 ".strlen($_POST[text])." 个 字 节 "; /获取 字符 串 长 度 
} 


> 
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(2) 将 该 文件 存储 于 \MR\02\093\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.67 所 示 。 
图 秘笈 心 法 


心 法 领悟 093: 使 用 strlen0 函 数 的 注意 事项 。 
使 用 stlen0 函 数 获取 字符 串 长 度 时 ， 如 果 字 符 串 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


实例 094 


图 实例 说 明 
使 用 sttlen0 函 数 可 以 统计 论坛 标题 的 长 度 ， 同 样 可 以 对 论坛 中 帖子 的 字 节 数 进行 统计 。 本 实例 通过 strlen0 
函数 对 论坛 中 帖子 的 字 节 数 进行 统计 ， 运 行 结果 如 图 2.68 所 示 。 


ig 


图 2.68 计算 论坛 帖子 的 字 节 数 


力 关键 技术 
本 实例 同样 应 用 strlen0 函 数 统计 字符 串 的 长 度 ， 并 且 应 用 自 定义 函数 对 提交 的 源 代码 进行 处 理 ， 保 证 源 代 
人 码 以 原形 式 输出 ， 而 不 会 输出 执行 文件 。 自 定义 函数 的 语法 如 下 : 
function unhtml($content) { 
$content=htmlspecialchars($content); 
Scontent=str_replace(chr(13),"<br>",$content); 


Scontent=str Teplace(chr(32)."&cnbsp:".$content); 
Teturn trim($content); 


图 设计 过 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 自 定义 函数 ， 然 后 定义 字符 串 变量 ， 接 着 应 用 strlen0 函 数 统计 帖子 内 
容 的 字 节 数 ， 并 且 通 过 自 定义 函数 对 帖子 内 容 进 行 转换 ， 其 代码 如 下 : 
本 unhtml($content){ 
$content=htmlspecialchars($content); 
$content=str_replace(chr(13)."<br>",$content): 
S$content=str replace(chr(32)."&nbsp:",Scontent); 
Teturn trim($content); 
于 PHP 编程 宝典 <br> 内 容 : PHP 编程 宝典 非常 好 !"; 
过 这 border="1" bordercolor="#FF0000" cellspacing="0"><tr><td> 
<?php echo $str:?> 
</td></tr></table> 
<?php 
echo "共有 字 节 ".strlen(unhtml(SstD)." 个 ": 
> 
(2) 将 该 文件 存储 于 \MR\02\09 人 文件 夹 下， 命名 为 index.php。 运 行 结果 如 图 2.68 所 示 。 
图 秘笈 心 法 
心 法 领悟 094: 自 定义 函数 unhtml0。 
自 定义 函数 unhtml0 主 要 用 于 对 提交 的 源 代码 进行 处 理 ， 保 证 源 代码 以 原形 式 输 出 ， 而 不 会 输出 执行 文件 。 
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高 级 
有 直 直 二 走 : 


图 实例 说 明 


用 微软 Windows 操作 系统 查找 文件 ， 可 以 使 用 CtrHF 快捷 键 实现 快速 定位 查找 。 本 实例 通过 stposO 函 数 
模拟 这 一 功能 实现 定位 查找 ， 运 行 结果 如 图 2.69 所 示 。 
吉林 省 明日 科技 有 限 公 司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 
级 日 科 技 。 【 证 人 下 的 ] 


吉林 省 明日 科技 有 限 公司 是 一 人 
查找 内 容 从 6 字 节 开始 、 字 符 旭 发 度 为 8 个 


图 2.69 实现 帖子 内 容 定 位 查找 


图 关键 技术 


在 PHP 中 实现 特殊 字符 的 查找 和 定位 可 以 通过 函数 stpos0 来 实现 ， 函 数 语法 如 下 : 
int strops(string strl ,string str2, [int offset]) 
此 函数 的 作用 是 在 strl 中 查找 sttr2， 并 返回 查找 到 的 位 置 。strpos0 函 数 实现 的 原理 比较 整个 要 查找 的 字符 
串 ， 并 返回 字符 串 str2 第 1 次 出 现 的 位 置 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 定 位 查找 ”按钮 时 ， 首 先 定义 一 个 字符 串 变 量 gemail。 然 后 ， 将 接收 到 
的 文本 框 数据 信息 进行 描 红 处 理 。 最 后 利用 sttposO 函 数 实现 帖子 内 容 的 定位 查找 ， 其 代码 如 下 : 
<?php 
这 $ POST[sub){ 
Semail = ' 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 ': 
S$str=$_POST[te]; 
S$strl = "<b style='color:red;>".$str."</b>"; 
echo str replace($str,$strl,$email)."<br>"; 
3 echo "查找 内 容 从 <b style='color:red;'>".strpos($email.$str)."</b> 字 节 开 始 , 字符 串 长 度 为 <b style='color:red;>".strlen($str)."</b> 个 字 
> 


(2) 将 该 文件 存储 于 \MR\02\095\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.69 所 示 。 
图 秘笈 心 法 


心 法 领悟 095: 知识 扩展 。 
strpos0 函 数 一 般 与 strlen0 函 数 联合 使 用 ， 得 到 的 两 个 结果 相当 于 substr0 函 数 的 两 个 位 置 参数 。 


高 级 


趣味 指数 : 信众 侠 俩 : 


图 实例 说 明 


用 户 在 编写 代码 时 也 许 会 在 不 经 意 间 多 输入 了 一 个 或 多 个 空格 ， 使 得 程序 无 论 怎么 调试 都 无 法 正常 运行 。 
本 实例 通过 trim0 函 数 实现 去 除 帖 子 标题 的 首尾 空格 ， 运 行 结果 如 图 2.70 所 示 。 
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未 去 掉 空格 前 字符 长 度 为 6 个 字 节 
去 挤 空 格 后 字符 长度 为 3 个 字 节 


图 2.70 去 除 帖 子 标题 的 首尾 空格 


图 关键 技术 

在 PHP 中 去 除 字符 串 的 首尾 空格 ， 可 以 使 用 函数 trim0 实 现 。trim0 函 数 的 语法 如 下 : 

string trim(string str); 

参数 说 明 : 

string str: 需要 过 滤 空 格 的 字符 串 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 提 交 ” 按 钮 时 ， 利 用 sttlen0 和 trim0 函 数 的 联合 操作 ， 实 现 输出 去 除 首 
尾 空格 前 、 后 的 字符 串 的 长 度 ， 其 代码 如 下 : 


<?php 
if($_POST[sub){ /通过 POST 方式 传递 参数 
echo "未 去 掉 空格 前 字符 长 度 为 ".strlen($_POST[text])." 个 字 节 <br>"; /输出 结果 
echo "去 掉 空 格 后 字符 长 度 为 ".strien(trim($_POST[text])." 个 字 节 "; /输出 结果 


} 
We 
(2) 将 该 文件 存储 于 \MR\02\096\ 文 件 夹 下 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.70 所 示 。 
图 秘笈 心 法 
心 法 领悟 096: 知识 扩展 。 
PHP 还 提供 有 单纯 去 除 字符 串 左 边 或 者 右边 空格 的 函数 ， 详 细 说 明 参 见 实例 083 。 


实例 097 趣味 指数 ， 禽 全 众生 | 


图 实例 说 明 


货币 数据 不 同 于 整 型 数据 , 其 是 存在 一 定格 式 的 。 本 实例 通过 函数 number_format0 实 现金 额 的 格式 化 输出 ， 
运行 结果 如 图 2.71 所 示 。 


清 输 出 金额 T5557 
[13,587.00 


2.71 金额 的 格式 化 输出 


图 关键 技术 
金额 的 格式 化 输出 通过 函数 number_format0 实 现 ， 其 语法 及 说 明 如 下 : 


string number format ( float number . int decimals) 

string number format ( float number, int decimals. string dec_point string thousands sep) 

number formatO 函 数 返 回 参数 number 格式 化 后 的 字符 串 ， 该 函数 可 以 有 1 个 、2 个 或 是 4 个 参数 ， 但 不 能 
是 3 个 参数 。 如 果 只 有 1 个 参数 number，number 格式 化 后 会 舍 去 小 数 点 后 的 值 ， 且 每 一 千 以 逗号 〈,) 隔 开 ， 
如 果 有 2 个 参数 ，number 格式 化 后 会 到 小 数 点 第 decimals 位 ， 且 每 一 千 就 会 以 去 号 来 隔 开 ; 如 果 有 4 个 参数 ， 
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number 格式 化 后 会 到 小 数 点 第 decimals 位 ，dec_point 用 来 蔡 代 小 数 点 〈.) ，thousands_sep 用 来 奉 代 每 一 千 隔 
开 的 逗号 (,) 。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 当 单 击 “ 格 式 化 ”按钮 时 ， 程 序 自动 将 文本 框 中 的 信息 进行 格式 化 ， 代 码 如 下 : 


这 S_POST[sub])f /通过 POST 方式 传 参 
echo number format($_ POST[text],2); /格式 化 数字 


} 
> 
(2) 将 该 文件 存储 于 \MRM\02\097 文件 夹 下 ， 命 名 为 index.php。 运 行 结 果 如 图 2.71 所 示 。 


图 秘笈 心 法 


心 法 领悟 097: 函数 应 用 。 
开发 电子 商务 类 网 站 ， 函 数 number format0 出 现 的 频率 是 百分之百 的 ， 所 以 掌握 此 函数 是 十 分 必要 的 。 


人 a 
098 趣味 指数 : 妇女 妇 页 
力 实例 说 明 


在 PHP 程序 设计 中 ， 经 常用 到 对 日 期 、 时 间 的 格式 化 输出 。 本 实例 通过 函数 date0 实 现 日 期 、 时 间 的 格式 
化 输出 ， 运 行 结果 如 图 2.72 所 示 。 


是 未 当前 日 期 时 间 2010-06>24 18:51 04 
图 2.72 日 期 、 时 间 的 格式 化 输出 


力 关键 技术 

本 实例 的 关键 点 是 date0 函 数 的 灵活 运用 ， 详 细 说 明 详 见 实例 035。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 当 单 击 “ 显 示 当前 日 期 、 时 间 ” 按 钮 时 ， 利 用 date0 函 数 根据 传 入 的 指定 的 参数 格式 
实现 格式 化 输出 ， 代 码 如 下 : 


date_default_timezone_set("Asia/ShangHai"); // 设 置 时 区 
If($_GET[date] 一 D{ /通过 GET 方式 取得 参数 
echo date("Y-m-d Hii:s"): /格式 化 输出 时 间 和 日 期 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\098 文件 夹 下 ， 命 名 为 mdex.php。 运 行 结果 如 图 2.72 所 示 。 
图 秘笈 心 法 


心 法 领悟 098: 获取 当地 时 间 。 
获取 当地 时 间 时 一 定 要 首先 设置 时 区 ， 和 否则 PHP 默认 使 用 的 是 英国 伦敦 的 零 时 区 ， 而 在 我 们 本 地 使 用 的 是 
北京 时 间 ， 即 东 八 区 的 时 间 。 设 置 时 区 时 ， 可 使 用 date_default_timezone_set("Asia/ShangHai") 语 句 。 
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ed 


度 高 级 
趣味 指数 ， 请 商户 南 


实例 099 


图 实例 说 明 


在 论坛 程序 中 比较 两 个 帖子 是 否 相同 可 以 屏蔽 重复 帖子 ， 节 省 资源 空间 。 本 实例 通过 字符 串 函数 
similar textO 比 较 两 个 帖子 的 相似 度 ， 运 行 结果 如 图 2.73 所 示 。 


比 对 帖子 的 相似 度 


字符 串 1， [PP 比 字符 串 2: [PP 
字符 串 1 与 字符 串 2 疹 3 个 字符 相同 , 相似 度 为 100% 


2.73 ” 比 对 论坛 中 帖子 的 相似 度 


力 关键 技术 


PHP 中 字符 串 相似 度 的 获取 可 以 通过 函数 similar_text0 来 实现 。 其 语法 格式 如 下 : 
int similar_text(sting strl,string str2,[double precent]) 


该 函数 用 于 比较 字符 串 strl 和 字符 串 str2 的 相似 程度 ， 函 数 的 返回 结果 是 字符 串 strl 和 字符 串 str2 的 相同 
字符 的 个 数 ， 而 可 省 参数 precent 的 值 是 这 两 个 参数 的 相似 度 。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 当 单 击 “ 比 较 ” 按 钮 时 ， 首 先 ， 分 别 获取 字符 串 1 和 字符 串 2 中 的 数据 ， 然 后 ， 利 
用 字符 串 函数 simlar textO 实 现 字符 串 相似 度 的 获取 ， 代 码 如 下 : 

<?php 


if($_POST[sub){ // 通 过 POST 方式 接收 参数 
$a = similar_text($_POST[te],$_POST[tex]); /判断 两 个 字符 串 的 相似 度 
if(strlen($_POST[te]) >= strlen($_POST[tex]){ 1/ 计算 百分比 


echo "字符 申 1 与 字符 申 2 有 "$a." 个 字符 相同 ,相似 度 为 "(Sa/strlen($_POSTte])*100)."96"; 
else{ 
echo "字符 申 1 与 字符 串 2 有 ".$a." 个 字符 相同 ,相似 度 为 "(Sa/strlen($_POST[tex])*100)."96"; 
} 
(2) 将 该 文件 存储 于 \MR\02\099 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.73 所 示 。 
图 秘笈 心 法 


心 法 领悟 099: similar textO 函 数 的 原理 。 
similar textO) 函 数 的 原理 是 对 应 比较 每 个 字 节 并 根据 结果 计算 百分比 。 


趣味 指数 : 傅 诊 疹 商 : 


力 实例 说 明 


对 于 电子 商务 网 站 的 用 户 来 说 ， 最 重要 的 就 是 账号 密码 的 安全 性 。 如 果 账 号 密码 未 经 过 加 密 处 理 ， 则 会 大 
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大 增加 安全 隐患 ， 给 非法 用 户 以 可 乘 之 机 。 本 实例 是 通过 字符 串 函数 base64_encode0 和 base64_decode0 实 现 对 
密码 的 加 密 和 解密 ， 运 行 结果 如 图 2.74 所 示 。 
用 户 各 训 yanenine 


这 友 Beeeeeeeel 
经 加 密 

用 户 名 ，yangni ne 密码 ，NTWzNT cxltzAx 
经 解密 


图 2.74 对 用 户 注册 的 密码 进行 加 密 和 解密 


力 关键 技术 


对 字符 串 的 base64 编码 可 以 通过 PHP 的 预定 义 函 数 base64_encode0 实 现 ， 其 语法 如 下 : 
String base64_encode(string str) 
该 函数 实现 对 字符 串 str 的 base64 编码 。 
对 已 经 进行 base64 编码 的 字符 串 进行 解码 用 函数 base64_decode0 实 现 ， 其 语法 如 下 : 
string base64_decode(sting str) 
该 函数 实现 对 已 经 进行 base64 编码 的 字符 串 进行 解码 。 
图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “ 提 交 ” 按 钮 时 ， 通 过 字符 串 函数 base64_encode0 和 base64_decode0 实 现 对 
字符 串 的 加 密 和 解密 ， 代 码 如 下 : 
这 $_POST[sub]){ /通过 POST 方式 接收 参数 
echo "经 加 密 <hr>"; 


echo "用 户 名 : ".$_POST[text]; 
Sstr = base64_encode($_ POST[pwd]); // 对 密码 进行 加 密 


echo "密码 : ". base64_decode($stn); /对 密码 进行 解密 
} 


(2) 将 该 文件 存储 于 \MRMO2\100 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.74 所 示 。 
图 秘笈 心 法 


心 法 领悟 100: 加 密 函 数 的 应 用 。 
base64_encode0 加 密 技术 在 邮件 系统 建设 等 方面 也 得 到 了 广泛 的 应 用 。 

os 

高 级 

趣味 指数 : bball 


图 实例 说 明 


表单 的 提交 方式 有 两 种 : GET 方式 和 POST 方式 。GET 方式 属于 明文 地 址 栏 传 参 ， 存 在 安全 隐患 。 本 实例 
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通过 urlencode0 函 数 实现 保护 URL 地 址 中 传递 的 参数 ， 运 行 结果 如 图 2.75 所 示 。 


hts//192. 168. 1. 59/mr/02/101/index DhpTidi 1 7 28 


文件 篇 铝 E) 查看 WW) 收藏 如 工具 ) 帮助 o 正 了 
[SRTZCCTEITTTTRTFTTZTS [二 下 二 避 


对 地 址 栏 参数 加 密 司 
而 TTT Ow 局 


图 2.75 保护 URL 地 址 中 传递 的 参数 


图 关键 技术 

PHP 中 字符 串 的 ul 编码 通过 函数 urlencode0 实 现 ， 其 语法 如 下 : 

string urlencode(string stD) 

该 函数 实现 对 字符 串 str 的 url 编码 。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 定 义 字符 串 变量 ， 将 此 字符 串 变 量 通过 函数 urlencodeO 进 行 编码 ， 然 后 将 编码 后 的 
字符 串 变量 以 拼接 地 址 栏 参数 的 形式 定义 在 超 链接 中 ， 代 码 如 下 : 


<?php 
a // 定 义 字符 串 
$str = urlencode($str); // 对 字符 串 进行 编码 
?> 
<a href="index.php?<?php echo $str:?>"> 对 地 址 栏 参数 加 密 </a> /链接 
(2) 将 该 文件 存储 于 \MR\02\101 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.75 所 示 。 
图 秘笈 心 法 


心 法 领悟 101: 知识 拓展 。 
经 编码 的 URL 参数 是 可 以 通过 urldecodeO 函 数 进行 解码 的 ， 详 细 说 明 详 见 本 实例 。 即 使 不 对 URL 编码 后 
的 参数 进行 解码 ， 同 样 也 可 以 获取 到 传递 的 参数 值 。 


高 级 
趣味 指 煞 全 全 全 页 


| 
| 


力 实例 说 明 
本 实例 通过 urldecodeO 函 数 解析 URL 地 址 中 传递 的 参数 值 ， 运 行 结果 如 图 2.76 所 示 。 
http: /192. 168.1.59/ar/02/102/iaaee pi 和 二 TE| 
文件 上 编辑 四 查看 Y) 收 屿 0) 工具 CD) 帮助 吕 区 2 
于 村 0 | 司 Mtp://192 163. 1 s/w/02/102/index py?izr20=x20! 。 本 || 因 区 到 | 诗 按 当 | 
让 攻 基地 0 放 Mit 攻 估 时 : 
[3] OT 
图 2.76 解析 URL 地址 中 传递 的 编码 参数 
力 关键 技术 
对 已 经 进行 URL 编码 的 字符 串 进行 解码 使 用 urldecode0 函 数 ， 语 法 如 下 : 
string urldecode ( string stD: 
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图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变 量 赋值 。 然 后 ， 将 字符 种 变量 进行 URL 编码 
处 理 。 最 后 ， 单 击 超 链接 ， 并 将 连接 地 址 用 urldecode0 函 数 解码 ， 代 码 如 下 : 

<?php 


er /定义 字 符 申 
S$str = urlencode($str); /对 [进行 编码 
$strl = urldecode($str); / 压 中 进行 解析 
?> 
<a href="index.php?<?php echo $str1;?>"> 对 地 址 栏 参数 解析 </a> // 地 址 栏 传 参 
(2) 将 该 文件 存储 于 \MR\02\102 文件 夹 下 ， 命 名 为 mdexphp。 运 行 结果 如 图 2.76 所 示 。 
图 秘笈 心 法 


心 法 领悟 102: URL 编码 是 否 可 以 应 用 于 防止 SQL 注入 。 
URL 编码 不 能 有 效 地 防止 SQL 注入 ， 原 因 在 于 URL 编码 可 以 解析 。 


实例 103 


图 实例 说 明 


实例 043 已 经 向 用 户 介绍 过 “\” 转 义 特殊 字符 的 方法 。 下 面 通 过 函数 quotemeta0 实 现 转 义 特殊 字符 ， 运 行 
结果 如 图 2.77 所 示 。 


转 扬 前 : $.\+ ?0^Omingri 
转 光 后 : IANANNAANWmingi 


图 2.77 特殊 字符 的 转换 


图 关键 技术 
为 了 方便 特殊 字符 的 原样 输出 ，PHP 提供 了 函数 quotemeta0， 其 语法 如 下 : 
string quotemeta(string str) 


此 函数 的 作用 是 在 字符 串 str 中 的 某 些 字符 前 面 加 上 反 斜 杠 “\”， 这 些 特殊 字符 主要 有 “.”、“\”、“+”、 
人“(”、“)”、“$”， 其 中 如 果 “$” 后 面 的 字符 与 “$” 共 同 构成 了 一 个 
合法 的 变量 名 ， 则 “$” 前 不 加 “\”。 
全 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 将 一 系列 特殊 符号 赋 给 变量 。 然 后 ， 通 过 函数 quotemetaO 

将 字符 串 变 量 进行 转 义 输出 ， 代 码 如 下 : 

<?php 


S$Ss= mingri /定义 字符 串 变量 
Sstr="$.\+*?0] O08s"; /定义 字符 串 变量 
echo" 转 换 前 : ".$str."<br>"; 
echo "转换 后 :".quotemeta($str); /| 转换 特殊 字符 


> 

(2) 将 该 文件 存储 于 \MR\02\103 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.77 所 示 。 
图 秘笈 心 法 

心 法 领悟 103: 解决 无 法 原样 输出 字符 的 问题 。 
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在 进行 PHP 项 目 开发 过 程 中 ， 经 常会 遇 到 一 些 无 法 原样 输出 的 字符 ， 解 决 办 法 就 是 通过 转 义 字符 进行 
转 义 。 


高 级 
趣味 指数 : 走穴 二 二 


| 
让 


图 实例 说 明 


敲 击 计算 机 键盘 上 的 任意 一 个 按键 都 要 经 过 ASCII 码 转 换 后 显示 到 屏幕 上 。 本 实例 通过 字符 串 函数 ord0 
实现 将 字符 转换 为 ASCI 码 ， 运 行 结果 如 图 2.78 所 示 。 


Pp 转换 


P 的 ASCII 码 为 ，80 


图 2.78 获取 任意 字符 的 ASCI 码 


图 关键 技术 
PHP 中 获取 字符 的 ASCII 码 应 使 用 ord0 函 数 ， 其 语法 如 下 : 
int ord ( string string): 
该 函数 预期 返回 一 个 整 型 数值 。 


图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “ 转 换 ” 按 钮 时 ， 通 过 字符 串 函数 ord0 获 取 指定 字符 串 的 ASCII 码 ， 代 码 
如 下 : 


这 $_POST[sub]){ /通过 POST 方式 传递 参数 
echo "$_ POST[text] 的 ASCIT 码 为 :"; /输出 
echo ord($_POST[text]): /WASCI 转 码 
|; 
> 
(2) 将 该 文件 存储 于 \MR\02\104 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.78 所 示 。 
力 秘笈 心 法 


心 法 领悟 104: 知识 拓展 。 
像 HTML 标签 “<br>” 等 都 可 以 在 ASCII 码 中 找到 相同 功能 的 ASCII 码 值 。 


图 实例 说 明 
本 实例 是 通过 字符 串 函 数 chr0 实 现 将 ASCII 码 转换 为 字符 ， 运 行 结果 如 图 2.79 所 示 。 
[uz | 
了 2 的 ASCII 碍 为 5 


2.79 ”查找 指定 ASCI 码 对 应 的 字符 
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图 关键 技术 


将 ASCII 码 转换 为 字符 可 以 通过 函数 chr0 实 现 ， 其 语法 如 下 : 

该 商 数 可 将 ASCII 序数 值 转换 成 对 应 的 字符 ， 与 ord0 函 数 成 对 照 。 
图 设计 过 程 

(1) 创建 PHP 脚本 。 当 单 击 “ 转 换 ” 按 钮 时 ， 首 先 ， 利 用 POST 方法 获取 文本 框 中 传 入 的 数据 信息 。 然 
后 ， ha chr0 函 数 转 换 为 ASCII 码 并 实现 输出 ， 代 码 如 下 : 


这 $_ POST[sub]){ /通过 POST 方式 传 参 
echo "$_POST[text] 的 AsCI 码 为 : /输出 
echo chr($_POST[text]); /AscI 对 应 的 字符 
pa 
(2) 将 该 文件 存储 于 \MR\02\105 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.79 所 示 。 
图 秘笈 心 法 


心 法 领悟 105: ASCII 码 的 优点 。 
ASCII 码 在 程序 开发 中 的 使 用 相当 广泛 ， 在 某 些 时 候 将 字符 转换 成 ASCII 码 而 被 系统 识别 ， 既 能 保证 安全 
性 ， 又 能 获取 更 好 的 支持 。 


高 级 
趣味 指数 : 寅 穴 寅 容 


国 实例 说 明 


为 了 使 上 传 文件 的 名 称 不 至 于 与 服务 器 已 有 文件 的 名 称 重 名 ， 合 理 定义 上 传 文件 的 名 称 就 显得 十 分 重要 。 


本 实例 通过 rand0 函 数 合理 定义 上 传 文件 的 名 称 ， 运 行 结果 如 图 2.80 所 示 。 
le 2 rn 个 点 起 和 1 人 二 


过 择 上 传 文件 : 5: \Docunents and Sett 让 


上 传 图 片 大 小 为 《28 )》 


ED ED 


文件 1264345109ereatexnlhttp. js 上 传 成 功 , 大 小 为 : 342 


Copyright @ 1999-2010 吉林 省 明日 科技 有 限 公司 


图 2.80 合理 定义 上 传 文件 的 名 称 


力 关键 技术 


在 PHP 中 应 用 move_uploaded file0 函 数 实现 文件 的 上 传 。 但 是 ， 在 执行 文件 上 传 之 前 ， 为 了 防止 潜在 的 攻 
击 对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 , 可 以 先 应 用 is_uploaded_ file0 函 数 判 断 指定 的 文件 是 否 是 通过 
HTTP POST 上 传 的 ， 如 果 是 ， 则 返回 TRUE。 
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(1) is_uploaded file0 函 数 


该 函数 用 于 判断 指定 的 文件 是 否 是 通过 HITP POST 上 传 的 ， 其 语法 如 下 : 


boolis_ uploaded file ( string filename ) 


参数 filename 必须 指定 类 似 于 $_ FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 


$_FILES['filename']['name']。 


通过 is_uploaded file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 


件 ， 例 如 /etc/passwd。 
(2) move_ Uploaded file0 函 数 


使 用 该 函数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返 回 


bool move_uploaded file ( string filename, string destination ) 


TRUE， 否 则 返回 FALSE， 语 法 如 下 : 


参数 flename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指 文件 上 传 后 保存 的 新 
路 径 和 名 称 。 如 果 参 数 filename 不 是 合法 的 上 传 文件 , 不 会 出 现任 何 操作 ，move_uploaded_file0 将 返回 FALSE; 
如 果 参 数 filename 是 合法 的 上 传 文件 ， 但 由 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ，move_uploaded file0 


将 返回 FALSE， 此 外 还 会 发 出 一 条 警告 。 
(3) rand0 函 数 
使 用 该 函数 生成 的 随机 整数 作为 上 传 文件 的 新 名 称 。 


图 设计 过 程 


创建 index.php 文件 , 添加 表单 ,设置 文件 域 .提交 按钮 , 使 用 POST 方法 ,设置 enctype="multipart/form-data"， 
通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload file0 函 数 完 成 图 片上 传 ， 其 代码 如 下 : 


这 !empty($_FILES[up_picture][name])){ 

这 $_FILES[up_picture][error]>0){ 
echo "上 传 错误 :"; 
switch($_FILES['up_picture"['eror]) { 


case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 ”: 
ease2 


2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 ": 
break: 


Case 3: 
echo "上 传 文件 不 全 "; 


case 4: 
echo "没有 上 传 文件 "; 
break: 


Yelsef 
ift!is_dir("./upfile/"){ 
mkdir("./upfile/"); 


} 
Spath="./upfile/.randO.$_FILES["up_picture"]['‘name]; 
ifis_uploaded_file($_FILES[up_picture][tmp_nameJ)){ 
if(!move_uploaded file($S_ FILES[up_picture][tmp_name'].Spatb)){ 
echo "上 传 失 败 ": 
Jelse{ 


/判断 上 传 内 容 是 否 为 空 
1/ 判断 文件 是 否 可 以 上 传 到 服务 器 


1/ 判断 指定 目录 是 否 存在 
// 创 建 目录 


// 定 义 文件 名 称 和 存储 位 置 
/| 是否 是 HTTP POST 上 传 
/执行 上 传 


echo "文件 "time0.$_FILES[up_picture][mame]." 上 传 成 功 ， 大 小 为 : "S$_FILES[up_picture][size]: 


} 
jelsef 
echo "上 传 文件 "$S_FILES[up_pictute][mame']." 不 合法 ! ": 
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图 秘笈 心 法 


心 法 领悟 106: 上 传 文件 的 命名 问题 。 
上 传 文件 如 果 和 已 有 文件 重 名 ， 文 件 可 能 会 相互 替换 ， 给 网 站 造成 损失 。 所 以 确保 上 传 文件 名 称 的 唯一 性 
是 非常 必要 的 ， 也 可 以 通过 time0 时 间 惟 来 定义 上 传 文件 的 名 称 。 


下 食 食 食 售 : 


实例 107 


图 实例 说 明 


本 实例 通过 异 或 方式 对 用 户 注册 的 密码 进行 加 密 ， 并 且 输 出 加 密 后 的 密码 ， 运行 结果 如 图 2.81 所 示 。 


用 户 名 训 rmeaine__ 
富 如 eeeeee 


入 去 angning 
码 ， JR 


图 2.81 通过 异 或 方式 对 用 户 注册 密码 进行 加 密 


力 关键 技术 


通过 异 或 方式 对 字符 串 加 密 的 原理 : 当 一 个 字符 串 A 与 另 一 个 字符 串 B 进行 异 或 运算 后 会 产生 一 个 字符 


图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变量 赋值 。 然 后 ， 通 过 异 或 方式 对 字符 串 变 量 
进行 加 密 并 输出 加 密 结果 ， 代 码 如 下 : 

<?php 


这 $_POST[sub])f /通过 POST 方式 传 参 
S$str= "0123456798"; /定义 字符 串 
echo "用 户 名 : ".$_POST[text]."<br>"; 
echo " 密 &nbsp:&nbsp: 码 : ".($_POST[pwd]^$str); // 异 或 加 密 

} 


将 该 文件 存储 于 \MR\02\107 文件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.81 所 示 。 
图 秘笈 心 法 


心 法 领悟 107: 比较 异 或 方式 与 md50 加 密 技术 。 
PHP 中 对 字符 串 加 密 的 方式 有 很 多 种 ， 像 md50 加 密 等 。 异 或 方式 与 md50 加 密 方式 的 本 质 区 别 是 md50 加 
密 后 不 能 解密 ， 异 或 方式 可 以 。 相 对 而 言 ，md50 加 密 更 加 安全 。 


| 
趣味 指数 ， 请 病 雇 识 | 


力 实例 说 明 


网 站 的 国际 化 已 经 不 是 一 个 炙手可热 的 话题 ， 但 是 由 于 地 区 差异 ， 在 使 用 英文 填写 注册 信息 时 ， 首 字母 的 
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大 小 写 往往 得 不 到 统一 。 本 实例 利用 函数 ucfirst0 实 现 将 英文 注册 用 户 首 字母 统一 为 大 写 ， 运 行 结果 如 图 2.82 
所 示 。 


用 户 名 :heaalomm 
IE 


首 字母 统一 为 大 写 #HeILo PHP 
图 2.82 ”统一 英文 注册 用 户 首 字 母 的 大 小 写 


图 关键 技术 


在 PHP 开发 中 , 定义 首 字母 大 写 的 方法 有 很 多 , 但 是 所 有 的 方法 都 没有 使 用 PHP 预定 义 函数 ucfirst0 简 单 。 
ucfirst0 的 语法 如 下 : 

string ucfirst ( string str ); 

参数 说 明 : 

string str: 定义 字符 串 。 


设计 过 程 
(1) 创建 PHP 脚本 。 当 单 击 “ 提 交 ” 按 钮 时 ， 首 先 ， 利 用 POST( 方 法 获取 从 文本 框 传递 进来 的 数据 。 然 
后 ， 将 获取 的 数据 经 ucfirstO 函 数 转换 首 字母 大 写 ， 最 后 ， 输 出 经 转换 后 的 数据 ， 代 码 如 下 : 
<?pl 


hp 
这 $_POST[sub]){ /通过 POST 方式 传 参 
S$a=$_POST[text]: /| 接收 参数 
echo " 首 字 母 统一 为 大 写 
echo ucfirst($a); /转换 单词 首 字母 


?> 
(2) 将 该 文件 存储 于 \MR\02\108 文件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.82 所 示 。 
也 笈 心 法 
心 法 领悟 108: 知识 拓展 。 
实现 字符 串 首 字母 大 小 写 转换 还 可 以 通过 转 码 来 完成 。 首 先 利用 函数 substr0 提 取出 字符 串 的 首 字母 ， 之 后 
利用 函数 ord0 获 取 该 字母 的 ASCII 码 , 再 根据 大 小 写字 母 之 间 相 差 32 来 实现 大 小 写字 母 之 间 的 ASCI 码 转 换 ， 
最 后 利用 函数 chr0 将 转变 后 的 ASCII 码 转 变 为 字母 即 可 。 


实例 109 


力 实例 说 明 


来 看 两 个 变量 $a = 123; 和 $a = “123”;。 前 者 是 整 型 变量 ， 后 者 是 字符 型 变量 。 本 实例 利用 函数 使 字符 型 变量 
转换 为 整 型 变量 ， 整 型 变量 转换 为 字符 型 变量 ， 运 行 结果 如 图 2.83 所 示 。 
转 扬 前 类 型 为 : string， 原 字符 囊 镁 出 : 123 
转 各 后 输出 :123 ) 转换 后 类 型 为 :integer 


读 贡 前 类 型 为 ,initeger , 原 字 符 事 输出 : 123 
转换 后 答 出 : 123) 竺 换 后 类 型 为 : string 


图 2.83 字符 串 与 数字 之 间 的 转换 
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图 关键 技术 
在 PHP 中， 将 数字 转换 为 字符 串 可 以 通过 函数 strval0 实 现 ， 其 语法 如 下 : 
string strval ( mixed var) 
该 函数 用 于 返回 变量 var 对 应 的 string 值 。 
设计 过 程 
(1) 首先 创建 脚本 文件 ， 定 义 字符 串 变 量 并 将 数值 型 字符 串 赋 给 变量 。 然 后 通过 strval0 函 数 转 换 数据 ， 代 
码 如 下 : 
<?php 
$str = "123"; /定义 字符 串 
echo "转换 前 类 型 为 :".gettype($str); /取得 当前 数据 类 型 
echo "， 原 字符 串 输出 : ".Sstr 
echo "<br>"; 
echo "转换 后 输出 ; ".intval(Sstr); // 将 字符 串 转换 为 整 型 
echo "， 转 换 后 类 型 为 :，".gettype(intval($str)); /取得 转换 后 的 数据 类 型 
echo “<hr>"; 
Sint = 123; /定义 整 型 变量 
echo "转换 前 类 型 为 : ".gettype(Sint): /取得 当前 类 型 
echo "， 原 字符 串 输出 : "Sint 
echo "<br>"; 
echo "转换 后 输出 : ".strval($int); /转换 为 字符 串 
echo "， 转 换 后 类 型 为 ，".gettype(strval(Sinb); /输出 转换 后 的 数据 类 型 
> 
(2) 将 该 文件 存储 于 \MR\02\109 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.83 所 示 。 
图 秘笈 心 法 


心 法 领悟 109: 简 述 strval0 和 intval0 函 数 。 
strval0 和 intval0 函 数 在 实现 功能 上 与 强制 类 型 转换 机 制 相同 


实例 110 


实例 说 明 

字符 种 匹 配 查找 的 方法 有 很 多 ， 下 面 来 了 解 如 何 用 正则 表达 式 对 字符 串 进行 匹配 查找 。 本 实例 是 通过 数组 
函数 和 正则 表达 式 函 数 preg_match0 来 实现 字符 串 的 匹配 查找 的 ， 运 行 结果 如 图 2.84 所 示 。 
[| 
mrsoft 


明日 mr 科技 


www.mrsoftcGm 


图 2.84 利用 正则 表达 式 实现 字符 串 的 匹配 查找 


图 关键 技术 


灵活 运用 正则 表达 式 函 数 是 本 实例 的 关键 。preg_matchO 函 数 用 于 匹配 指定 字符 串 ， 一 般 情况 下 ， 会 与 让 
条 件 语句 协同 使 用 ， 其 语法 如 下 : 

int preg_match ( string pattern. string subject [. array matches] ) 

函数 功能 : 在 字符 串 subject 中 匹配 表达 式 pattem。 函 数 返 回 匹配 的 次 数 。 如 果 有 数组 matches， 那 么 每 次 
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匹配 的 结果 将 被 存储 到 数组 matches 中 。 该 函数 在 匹配 成 功 后 就 停止 继续 查找 ， 其 返回 值 是 0 或 1。 
图 设计 过 程 
(1) 创建 PHP 脚本 。 首 先 ， 定义 数 组 变量 $a 并 为 $a 赋值 。 然 后, 利用 foreach0 语 句 遍 历数 组 以 便 取得 key 


值 和 value 值 。 最 后 ， 利 用 正则 表达 式 函 数 preg_match0 将 通过 POST 方法 传递 进来 的 数据 进行 匹配 ， 匹 配 成 功 
则 输出 对 应 数组 的 value 值 ， 代 码 如 下 : 


<?php 
$a = array(mrso 人 t,' 明 日 mr 科技 "www-mrsoftcom7: /定义 数组 
foreach($a as $key => $value){ //foreach0 循 环 遍历 数组 
$a=$ POST[tel; 
if(preg_match("/$a/",$value)){ // 正 则 表达 式 匹 配 
echo $value: 
echo "<br>"; 


} 
} 


> 
(2) 将 该 文件 存储 于 \MR\02\110 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.84 所 示 。 
图 秘笈 心 法 
心 法 领悟 110: SQL 语句 的 匹配 问题 。 
PHP 项 目 开 发 过 程 中 可 以 利用 SQL 语句 中 的 关键 字 like 对 数据 库 中 的 内 容 进 行 匹 配 查 找 , 其 实现 的 是 数据 
库 中 数据 的 模糊 查询 。 


高 级 


: 
实例 111 趣味 指数 : 会 会 侠 会 


力 实例 说 明 


了 P 地 址 是 互联 网 身份 的 象征 ， 通 过 人 P 地 址 可 以 得 到 用 户 的 相关 信息 。 本 实例 通过 正则 表达 式 验证 人 P 地 址 
是 否 合法 ， 然 后 实现 他 地址 的 格式 转换 ， 进 而 获取 他 地 址 所 在 地 ， 运 行 结果 如 图 2.85 所 示 。 


IPB 2 15 165.1-1 
对 应 数字 [5104546455 区 本 


图 2.85 利用 下 地 址 查找 主机 所 在 地 


力 关键 技术 


首先 需要 验证 输入 的 P 地 址 是 否 合法 ， 如 果 合 法 ， 再 将 其 转换 为 对 应 的 数值 。 验 证 瑟 地 址 是 否 合法 可 以 
通过 正则 表达 式 实现 。 

下 地 址 使 用 4 位 地 址 定位 设备 ， 它 采用 点 分 十 进 制 数 的 格式 “xxx.xxx.xxx.xXxx”， 例 如 192.168.1.66。 因 此 ， 
验证 卫 地 址 是 否 合法 的 正则 表达 式 如 下 : 

/daD Cab Gdab Gap/ 

将 四 地 址 转换 为 对 应 的 数值 可 以 应 用 以 下 公式 实现 : 

P1*255*255*255+P2*255*255+P3*255+P4*1 

在 上 面 的 公式 中 ，P1 代表 卫 地 址 第 1 段 的 数值 ，P2 代表 他 地址 第 2 有 段 的 数值 ，P3 代表 下 地址 第 3 段 的 
数值 ，P4 代表 下 地 址 第 4 段 的 数值 。 
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图 设计 过 程 
(1) 编写 JavaScript 脚本 ， 定 义 deal0 方 法 验证 用 户 提交 的 他 地址 格式 是 否 正确 ， 定 义 convert0 方 法 将 他 
地 址 转换 为 对 应 数值 ， 该 方法 只 有 一 个 参数 p， 用 于 指定 他 地 址 ， 返 回 值 为 他 地 址 对 应 的 数值 ， 代 码 如 下 : 


<script language="javascript"> 
function deal(myform){ / 自 定义 函数 
var ip=forml.ip.value: /定义 变量 
objExp=/(\d+).0d+).0d7).0d1)/; /正则 表达 式 
iflip—"){ 1/ 条 件 判 断 
alert(" 请 输入 卫 地 址 !":forml.ip .focusO:retum: 
if(objExp.test(ip){ 
myform.ipNum.value=convert(ip); 
}else{ 


alert(" 您 输入 的 他 地 址 不 合法 !");forml.ip.focusO:return; 


function convert(ip){ / 自 定义 函数 
ip=ip.split("."); 
vip=ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1:; /转换 程式 
Teturmn vip; /返回 值 
</script> 


(2) 创建 index.php 文件 ， 通 过 form 表单 提交 要 验证 的 瑟 地址 ， 调 用 JavaScript 脚本 中 的 方法 验证 了 P 地 
址 格式 和 完成 格式 的 转换 操作 。 
图 秘笈 心 法 
心 法 领悟 111: 使 用 $_SERVER["REMOTE ADDR"] 的 注意 事项 。 
在 PHP 中 ， 可 以 通过 $_ SERVER["REMOTE ADDR"] 获 取 客户 机 的 人 P 地 址 ， 但 并 不 能 判断 该 卫 地 址 的 所 
在 地 。 如 果 要 判断 瑟 地 址 的 所 在 地 就 必须 对 其 格式 进行 转换 。 


文字 符 串 截取 时 出 现 乱码 的 问题 高 级 | 
趣味 指数 : 请 商 请 请 


图 实例 说 明 


使 用 substr0 函 数 是 按 字 节 截 取 字 符 串 的 ， 在 截取 中 文字 符 串 时 ， 由 于 一 个 汉字 由 两 个 字符 组 成 ， 如 果 只 
截取 1 个 字符 就 会 出 现 乱码 。 本 实例 使 用 自 定义 函数 解决 对 中 文字 符 串 截取 时 的 乱码 问题 ， 运 行 结果 如 图 2.86 
所 示 。 


吉林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 


从 勿 1 字 开 始 直 到， 截取 ”个 字 ， 匡 到 ] 
吉林 省 明日 科技 有 限 公司 
图 2.86 解决 用 substr0 函 数 对 中 文字 符 串 截取 时 的 乱码 


图 关键 技术 


对 中 文字 符 串 的 截取 虽说 是 通过 自 定义 函数 来 完成 的 ， 但 是 其 根本 还 是 应 用 substr0 函 数 ， 只 是 在 进行 字符 
串 截取 时 ， 对 字符 串 的 类 型 进行 了 判断 。 
对 截取 字符 串 中 首 个 字 节 的 ASCII 序数 值 进行 判断 ， 如 果 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 ， 那 么 在 
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应 用 substr0 函 数 进行 截取 时 ， 就 以 2 个 字 节 为 单位 ; 如 果 ASCII 序数 值 小 于 0xa0， 则 表示 为 英文 字符 串 ， 那 么 
在 应 用 substr0 函 数 进行 截取 时 ， 就 以 1 个 字 节 为 单位 。 这 样 将 中 文字 符 串 和 英文 字符 串 分 隔 进行 截取 就 避免 了 
出 现 乱码 的 问题 。 


自 定义 函数 msubstr0 的 语法 如 下 : 

function msubstr(S$str, $start, Slen) { /Sstr 指 的 是 字符 串 ，Sstart 指 的 是 字符 串 的 起 始 位 置 ，Slen 指 的 是 长 度 
$strlen = $start + $len: // 用 S$strlen 存储 字符 串 的 总 长 度 〔 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i= 0; $i< $strlen: $i++) { /通过 for 循环 语句 ， 循 环 读 取 字符 串 


计 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCHL 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr .= substr ( $str, Si 2 ); 。 // 每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 
$i++; /变量 自 加 1 
} else{ /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr .= substr ( $str, $i, 1 ); 
lL 
Tetum $tmpstr; /输出 字符 串 
} 
其 中 ， 参 数 gstr 是 指定 被 截取 的 字符 串 ， 参数 gstrart 是 截取 的 开始 位 置 ， 参 数 $len 是 截取 的 长 度 。 返 回 值 
$tmpstr 是 截取 后 的 字符 串 。 


图 设计 过 程 
创建 index.php 文件 ， 定 义 msubstr0 函 数 ， 对 中 文字 符 串 进行 截取 。 创 建 form 表单 ， 提 交 字 符 串 截 取 的 开 
始 位 置 和 长 度 ， 然 后 调用 msubstrO 函 数 对 字符 串 进行 截取 ， 并 且 输 出 截取 结果 ， 代 码 如 下 : 


?php 
function msubstr($str, $start, Slen) { /Sstr 指 的 是 字符 串 ，Sstart 指 的 是 字符 串 的 起 始 位 置 ，Slen 指 的 是 长 度 
S$strlen = $start + $len:; // 用 $strlen 存储 字符 串 的 总 长 度 〔 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i= 0: $i< $strlen; $i ++) { // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
证 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr .= substr ( $str, $i, 2 ); 。 // 每 次 取出 两 位 字符 赋 给 变量 $Stmpstr， 即 等 于 一 个 汉字 
S$i++; /变量 自 加 1 
} else { // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 


Stmpstr .= substr ( $str, $i, 1 ); 
1 
Tetum S$tmpstr; /输出 字符 串 


} 

$string=" 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 "; 
$str=msubstr($string,$_POST[te].$_POST[tx]); 

echo $str 


图 秘笈 心 法 


心 法 领悟 112: 利用 函数 截取 中 文字 符 串 的 注意 事项 。 
使 用 substr0 截 取 中 文 最 好 首先 定义 算法 ， 以 免 截 取 半 个 中 文 文字 而 出 现 乱 码 。 


趣味 指数 : 二 评语 全 


力 实例 说 明 


本 实例 是 通过 PHP 5.0 中 的 新 型 字符 串 实现 字符 串 与 HTML 标记 的 相互 转换 ， 运 行 结果 如 图 2.87 所 示 。 
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图 2.87 字符 串 与 HTML 标记 的 相互 转换 


图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 
图 设计 过 程 
创建 index php 文件 ， 利 用 PHP 5.0 新 型 字符 串 将 HTML 标记 封装 到 PHP 的 变量 中 ， 并 且 输 出 PHP 变量 的 


值 ， 代 码 如 下 : 
<?php 
Sstr=<<<mark // 新 型 字符 串 格 式 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 字 符 串 与 HTML 标记 相互 转换 </title> 
</head> 


<body background="../image/1.jpg" style="font-size:16px: color:blue; font-family:' 微 软 雅 黑 "><table border="1"><tr><td> 
用 户 名 : <input type="text" name="test" size="15" /><br> 
密 &nbsp;&enbsp;&nbsp; 码 ，<input type="password" name="pwd" size="15" /><br> 
<input type="submit" name="sub" value=" 提 交 " /> 

</form></td></tr></table> 

</body> 

</html> 

mark:; // 新 型 字符 串 结束 符 

echo Sstr; 

> 


图 秘笈 心 法 


心 法 领悟 113: 新 型 字符 串 的 应 用 范围 。 
新 型 字符 串 被 广泛 应 用 在 含有 较 多 的 HIML 标记 的 PHP 编码 中 。 


实例 114 


力 实例 说 明 


本 实例 通过 PHP 5.0 新 型 字符 串 输出 XML 格式 的 数据 ， 运 行 结果 如 图 2.88 所 示 。 


池 运 用 Ps 者 型 字符 审 答 出 T8L 涩 各 一 时 
文件 下” 编 辑 于 ) 查看) 收 宗谷) 
WED he /1 100 1 50/er/02/11/ ner php 


ts mingrisof com 吉林 省 明日 科技 有 限 公 
/forww mingnisoft com http /fwww mrbccd com 印 E 日 科技 编程 词 
ES 出 击 ， 隆 重 上 市 ! 2008-08-08 | 


同 半 尝 三 夏 |@ 可 六 站点 
2.88 PHP 5.0 新 型 字符 串 输 出 XML 格式 的 数据 
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图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 
图 设计 过 程 
创建 index.php 文件 ， 定 义 PHP 5.0 新 型 字符 串 ， 通 过 其 输出 XML 格式 的 数据 ， 代 码 如 下 : 
<?xml version="1.0" encoding="utf8"?> 
<rss xmlns:rdf="http://www.w3.0rg/1999/02/22-rdf-syntax-ns#" xmins:dc="http://purl.org/dc/elements/1.1/" 
xmins:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0"> 
<channel> 


<title> 明 日 科技 </title> 
<link>http://www.mingrisoft.com</link> 
<description> 吉 林 省 明日 科技 有 限 公司 </description> 
<dc:creator>http://www mingrisoft com</dc:creator> 


<item> 
<title> 编 程 词典 </title> 
<link>http://www.mrbccd.com</link> 
<description> 明 日 科技 编程 词典 重 拳 出 击 ， 隆 重 上 市 ! </description> 
<pubDate>2008-08-08</pubDate> 
<jitem> 
</channel></rss> 
mark; 
echo $str 
> 


秘笈 心 法 

心 法 领悟 114: 使 用 新 型 字符 串 的 优点 。 

在 PHP 5.0 之 前 的 开发 中 ， 想 要 在 PHP 中 输出 一 些 html 标记 是 通过 echo 语句 一 行 一 行 输出 的 ， 这 无 疑 是 
- 件 非常 头痛 的 事 。 现 在 PHP 提供 了 新 型 字符 串 ， 相 关 的 问题 就 可 迎刃而解 了 。 


存在 指定 子囊 高 级 | 


趣味 指数 : 窗 傅 傅 窗 | 


实例 115 


图 实例 说 明 


判断 一 个 字符 串 中 是 否 含有 另 一 个 字符 串 的 方法 有 很 多 ， 例 如 ， 正 则 表达 式 等 。 本 实例 通过 stristr0 函 数 判 
断 字符 串 中 是 否 存在 指定 子囊， 运行 结果 如 图 2.89 所 示 。 


Hier1d 
CE 


来 自 http://localhost 的 页 面 说 : 


Py 文本 不 存在 指定 子囊 


图 2.89 字符 串 中 不 存在 子 串 


图 关键 技术 


判断 一 个 字符 串 是 否 是 另 一 个 字符 串 的 子 串 可 通过 函数 stristr0 实 现 ， 其 语法 如 下 : 
string stristr ( string haystack, string needle ); 
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该 函数 获取 指定 字符 串 (A) 在 另 一 个 字符 串 〈B) 中 首次 出 现 的 位 置 到 字符 串 〈(B) 末尾 的 所 有 字符 串 。 
参数 haystack 指定 查找 的 字符 串 ， 参 数 needle 指定 查找 的 对 象 。 

该 函数 如 果 执 行 成 功 则 返回 剩余 的 字符 串 ， 否 则 将 返回 FALSE。 

设计 过 程 

创建 index.php 文件 ， 定 义 字符 串 变 量 ， 将 该 变量 与 通过 POSTO 方 法 传递 进来 的 数据 利用 stristr0 函 数 进行 
比较 并 输出 结果 ， 代 码 如 下 : 

<?php 


$a= "Hello World 5 /定义 字符 串 
echo $a; /输出 字符 串 
echo "<form action="method='post>"; /输出 表单 


echo "<input type='text name='text' valne= 输 入 文本 内 容 >": 
echo "<input type='submit name='sub' value=' 提 交 >"; 


echo "</form>"; 
if($_POST[sub){ /通过 POST 方式 传 参 
Mit POST[text) = ""){ // 判 断 是 否 存 在 子 串 
echo "<script>alert( 文 本 存在 指定 子 串 );</script>"; /提示 
Jelse{ 
echo "<script>alert( 文 本 不 存在 指定 子 串 ");</script>"; /| 提示 
》 
} 
> 
图 秘笈 心 法 


心 法 领悟 113， 知 识 扩展 。 
stristr0) 函 数 还 可 以 作为 分 割 函数 的 一 部 分 ， 从 符合 条 件 的 字符 串 开始 截取 ， 一 直到 文件 末尾 。 该 函数 不 区 
分 大 小 写 ， 如 果 要 在 区 分 字母 大 小 写 的 情况 下 进行 搜索 ， 可 以 应 用 strstr0 函 数 。 


2.9 正则 表达 式 


正则 表达 式 是 一 种 描述 字符 串 结构 模式 的 形式 化 表达 方法 ， 是 一 个 强大 、 便 捷 、 高 效 的 文本 处 理工 具 ， 可 
用 于 验证 用 户 输入 的 数据 和 检索 大 量 的 文本 。 在 PHP 中 , 表达 式 应 用 最 好 的 体现 是 对 表单 提交 的 数据 进行 验证 ， 
判断 是 否 合理 、 合 ; 


高 级 
趣味 梢 多: 页 让 


力 实例 说 明 


表单 注册 时 往往 要 求 用 户 书写 座机 电话 号 码 ， 而 座机 电话 号 码 是 由 11 位 或 12 位 数字 组 成 的 ， 所 以 一 定 要 
对 电话 号 码 的 位 数 和 格式 进行 限制 .本 实例 通过 正则 表达 式 和 正则 表达 式 函 数 preg_match0 实 现 对 电话 号 码 格式 
的 验证 ， 运 行 结果 如 图 2.90 所 示 。 


[rrr a Ei | 


2.90 ”验证 电话 号 码 的 格式 是 否 正确 
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力 关键 技术 


(1) preg_match0: 进行 正则 表达 式 匹配 。 

int preg_match ( string pattern, string subject [, array matches [. int flags]]); 

(2) 正则 表达 式 : 固定 总 位 数 为 11 位 或 12 位 的 座机 电话 。 

/dBjDGdfsDsSIGdt -DCdt7DS4: 
图 设计 过 程 

创建 index.php 文件 ,通过 正则 表达 式 函数 对 输入 文本 框 的 电话 号 码 进行 验证 ， 并 输出 相关 提示 ， 其 代码 
如 下 : 


这 $ POST[subTD{ 


这 preg_match(VCdf3}-)(df8DSICd{4-)Cdf79)S/.S_POSTIYext]D)) /正则 表达 式 验证 
include("inc.php"); // 包 含 信息 提示 页 
show_error(" 信 息 提 示 "," 格 式 正确 ","index.php"); // 调 用 自 定义 函数 输出 提示 信息 

jelsef 
include("inc.php"): 
show_error(" 信息 提示 "， "格式 错误 ","index.php"); /调用 自 定义 函数 输出 提示 信息 

} 

: 
> 
秘笈 心 法 


心 法 领悟 116: 使 用 正则 表达 式 的 注意 事项 。 
正则 表达 式 “/d{3}-)Gdf8)SICd{4}-)Gd{75S/” 是 根据 新 式 电话 号 码 设置 的 ， 老 式 的 座机 电话 是 由 10 位 数 
字 组 成 的 。 


国 实例 说 明 


互联 网 发 展 到 今天 , 几乎 所 有 的 Web 爱好 者 都 有 自己 的 Email 地 址 , 无 论 申 请 的 是 126 邮箱 还 是 163 邮箱 ， 
Email 地 址 的 格式 是 固定 的 .本 实例 通过 preg_matchO 正 则 匹配 函数 和 正则 表达 式 验证 Email 地 址 格式 是 否 正确 ， 
运行 结果 如 图 2.91 所 示 。 


验证 email 地 址 格式 是 否 正确 
IEC Ea 


图 2.91 验证 Email 地 址 格式 是 否 正确 


图 关键 技术 


(1) preg_ matchO 函 数 : 进行 正则 表达 式 匹 配 ， 详 细 参 数 参 见 实例 110。 
(2) 正则 表达 式 : 对 Email 地 址 进行 验证 。 
ARHEHETWDAGNWHELTWDANHECJwD 居 
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设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 , 通过 正则 表达 式 函 数 验 证 文本 框 传 入 的 信息 并 输出 对 应 提示 ， 
其 代码 如 下 : 
这 $_ POST[sub]){ 
Tequire_once("inc.php"); /包含 信息 提示 页 
if(preg_match("N\w+([-+.] w+)*@\Ww+([-. wi)*\ w+([- J w+)*/",trim($_ POST[textD))f // 正 则 表达 式 验证 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); /输出 提示 
jelsef 
了 show_error(" 信 息 提示 "," 格 式 不 正确 ","index.php"); // 输 出 提示 
} 
: 
> 
图 秘笈 心 法 


心 法 领悟 117: PHP 支持 的 两 种 正则 表达 式 函 数 库 。 
PHP 支持 两 种 正则 表达 式 函 数 库 ， 一 种 是 正则 表达 式 函 数 库 (POSIX 扩展 ) ， 另 外 一 种 是 正则 表达 式 函 数 
库 (Perl 兼容 ) 。 在 性 能 上 ，Perl 兼容 正则 表达 式 速度 更 快 一 些 。 


高 级 


趣味 指数 : 耸 耸 侠 商 | 


力 实例 说 明 


四 地 址 是 Web 用 户 可 以 访问 互联 网 的 身份 凭证 。 每 一 个 下 地址 相对 其 他 用 户 的 人 P 都 是 独立 的 。 本 实例 通 
过 正则 表达 式 函 数 preg_match0 和 正则 表达 式 对 他 地 址 进行 验证 ， 运 行 结 果 如 图 2.92 所 示 。 


验证 ip 地 址 格式 是 否 正 确 


图 2.92 ”验证 区 地 址 是 否 有 效 

图 关键 技术 

(1) preg_match all0 函 数 ， 在 字符 串 subject 中 匹配 表达 式 pattem， 函 数 返 回 匹配 的 次 数 。 如 果 有 数组 
matches， 那 么 每 次 匹配 的 结果 将 被 存储 到 数组 matches 中 ， 其 语法 如 下 : 

int preg_match_all ( string pattern. string subject [. array matches] ) 

(2) 正则 表达 式 : 对 下 地 址 进行 验证 。 

“dran\dr dr’; 
图 设计 过 程 

(1) 创建 index.php 文件 ， 通 过 form 表单 提交 电话 号 码 ， 当 单 击 “ 验 证 ”按钮 时 ， 通 过 正则 表达 式 函 数 验 
证 了 P 地 址 ， 并 且 返 回 验证 结果 ， 其 代码 如 下 : 


<zphp 
is_POSsT[sub]){ 
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if(preg_match_all(“/(\d{3}-)(d{8))sI(Nd{4}-)0d{7})S/".$_POSTT'text D.Scounts){ /验证 电话 号 码 
include("inc.php"); // 包 含 提示 文件 
show_error(" 信 息 提示 ".Scounts,"index.php"): 

jelsef 
include("“inc.php"); 
show_error(" 信 息 提示 ",Scounts,"index.php"); 

3 

}: 
> 


2) 创建 inc.php 文件 ， 定 义 方法 show_error0， 根 据 传递 的 参数 值 定义 返回 的 错误 信息 。 
图 秘笈 心 法 

心 法 领悟 118: 卫 地 址 是 什么 。 

Internet 为 每 一 个 主机 分 配 唯 一 的 一 个 32 位 地 址 ， 该 地 址 称 为 他 地 址 ， 也 称 网 际 地 址 。 人 P 地 址 由 4 个 数组 


成 ， 每 个 数 取 值 范围 为 0-255， 每 两 个 数 之 间 用 “.” 分 隔 。 所 以 人 P 地 址 的 格式 是 固定 的 ， 正 则 表达 式 
“AdrhNdtNdtdH” 可 以 验证 所 有 了 王 地 址 。 


趣味 指数 : 傅 人 富商 商 | 


图 实例 说 明 


统计 关键 字 的 查询 结果 的 方法 有 很 多 ， 本 实例 通过 正则 表达 式 函 数 split0 和 countO 实 现 统计 关键 字 ， 运 行 


结果 如 图 2.93 所 示 。 


PHP 作 为 全 球 最 萤 及 、 应 用 最 广泛 的 互联 网 开发 请 襄 之 一 ， 从 1994 年 证 生 至 今 已 核 2000 多 万 个 动态 网 站 胖 用 ,全球 
知名 互 联 周公 司 Google、Yahoo、egay 和 中 国 知名 网 站 新 浪 、 百 度 、 问 里 巴巴 等 均 采 用 PHP 技 术 上 


输出 关键 字 P 一 共 出 现 4 次 


图 2.93 统计 关键 字 的 查询 结果 


图 关键 技术 


splitO 函 数 : 用 正则 表达 式 将 字符 串 分 割 到 数组 中 。 

array split ( string pattern. string string [, int limit]): 

该 函数 返回 一 个 字符 串 数组 ， 每 个 单元 为 string 经 区 分 大 小 写 的 正则 表达 式 pattem 作为 边界 分 割 出 的 子 
串 。 如 果 设 定 了 limit， 则 返回 的 数组 最 多 包含 limit 个 单元 ， 而 其 中 最 后 一 个 单元 包含 string 中 剩余 的 所 有 部 
分 。 如 果 出 错 ， 则 split0 返 回 FALSE。 


力 设计 过 程 
创建 index.php 文件 。 首 先 ， 定 义 字 符 串 变 量 $str 并 为 $str 赋值 。 然 后 ， 利 用 split0 函 数 检索 字符 “p” 在 $str 
中 的 出 现 次 数 ， 并 输出 检索 的 结果 ， 其 代码 如 下 : 


<?php 
/定义 字符 串 变 量 

$str = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知名 互联 网 公司 
Google、Yahoo、eBay 和 中 国 知名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采用 PHP 技术 ! “: 
$b = split("P",Sstr); // 使 用 split0 函 数 进行 分 割 
echo "<h4 style =red>"; 

echo $str."<br>": 

echo "</h4>"; 
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echo "输出 关键 字 P 一 共 出 现 ".(count($b)-1)." 次 "; /利用 count0 函 数 进行 统计 


力 秘笈 心 法 


心 法 领悟 119: splitO 函 数 的 实现 原理 。 
split0 正 则 表达 式 函 数 是 将 字符 串 分 割 到 数组 中 , 如 果 字 符 串 中 有 n 个 与 pattem 匹配 的 项 目 , 则 返回 的 数 
组 将 包含 n+l 个 单元 ， 所 以 count0 在 计算 时 要 减 1。 


趣味 指数 :请 寅 商户 


力 实例 说 明 


计算 机 的 每 一 步 操作 都 是 需要 时 间 的 ， 只 不 过 由 于 时 间 过 于 短暂 用 户 感觉 不 到 。 本 实例 通过 时 间 改 函数 
microtimeO 计 算 查 询 操作 的 执行 时 间 ， 和 运行 结果 如 图 2.94 所 示 。 


id:1 
查询 操作 所 用 时 间 为 ， 0.004093 秒 


图 2.94 计算 查询 操作 的 执行 时 间 


图 关键 技术 


获取 查询 操作 的 执行 时 间 ， 在 PHP 中 主要 是 使 用 microtime0O 函 数 实现 ， 其 语法 如 下 : 
mixed microtime ( [bool get_as float] ); 


该 函数 获取 某 一 时 刻 的 时 间 改 的 微 秒 数 。 
图 设计 过 程 

创建 index.php 文件 。 首 先 ， 连 接 数 据 库 并 设置 页 面 的 编码 风格 ， 在 执行 查询 操作 的 开始 与 结束 的 两 个 时 间 
点 定义 两 个 变量 ， 分 别 利用 microtimeO 函 数 获取 两 点 时 间 惟 的 微 秒 数 。 然 后 计算 两 个 时 间 戳 的 差 值 ， 取 得 程序 
的 执行 时 间 ， 其 代码 如 下 : 

<?php 


S$conn = mysql_connect("localhost","root"."111")or die(" 连 接 mysql 出 现 错误 "); /连接 mysql 
mysql_select_db("db_database02", $conn): /连接 数据 库 

$sql = "SELECT * FROM tb_select"; /sql 语句 

$a = microtime(); 1/ 取得 当前 时 间 蕉 的 微 秒 数 
S$rs = mysql_query($sql):; /查询 操作 


while(Srst = mysql_fetch_armray(Srs)) 


echo "id:".$rst[0]."<br>"; 


$b = microtime0: /取得 当前 时 间 戳 的 微 秒 数 
echo "查询 操作 所 用 时 间 为 :".($b-$a)." 秒 "; /输出 结果 
> 
说 明 : 本 实例 所 用 的 数据 表 没有 足够 多 的 数据 ， 以 至 于 执行 速度 太 快 几乎 不 需要 时 间 ， 为 了 显示 结果 笔者 
人 为 让 程序 休眠 1 秒 钟 。 
图 秘笈 心 法 


心 法 领悟 120: 知识 扩展 。 
time0 和 mktimeO 在 不 指定 参数 的 情况 下 具有 相同 的 作用 , 都 是 返回 自从 UNIX 新 纪元 (格林 威 治 时 间 1970 
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年 1 月 1 日 00:00:00) 到 当前 时 间 的 秒 数 。 而 microtime0 函 数 只 是 单纯 取得 两 个 时 间 截 的 微 秒 数 。 


高 级 
趣味 指数 : 南 走 寅 全 


证 
让 
上 


图 实例 说 明 


关键 字 描 红 技 术 在 实例 088 中 已 经 进行 过 讲解 ， 本 实例 是 通过 正则 表达 式 蔡 换 函 数 preg_replace0 实 现 查 询 


关键 字 描 红 ， 和 运行 结果 如 图 2.95 所 示 。 


吉林 省 长 春 市 搜索 


且 户 隆 列 往 二 区 
号 明 | 男 | 吉林 省 长 春 市 |555555555555 
潮 凯 华 | 男 | 吉林 省 长 春 市 |666666666 


可 中 华 勇 1 震 林 省 长 春 市 |7777777777 


图 2.95 查询 关键 字 描 红 


图 关键 技术 


执行 替换 或 关键 字 描 红 时 经 常 使 用 PHP 预定 义 函数 preg_Ieplace0， 其 语法 如 下 : 
mixed preg_replace ( mixed pattemn, mixed replacement mixed subject [, int limit] ): 

参数 说 明 : 

mixed pattern: 规定 蔡 换 规则 。 

mixed replacement: 替换 部 分 。 

mixed subject: 替换 内 容 的 源 信息 。 

主要 功能 : 执行 正则 表达 式 的 搜索 和 替换 。 


图 设计 过 程 
创建 index.php 文件 。 首 先 ， 连 接 数据 库 并 设置 页 面 的 编码 风格 。 然 后 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 执 行 查 询 
操作 并 将 文本 框 输入 的 信息 进行 描 红 处 理 。 最 后 ， 利 用 正则 表达 式 函 数 preg_replaceO 蔡 换 数 据 信息 ， 其 代码 


如 下 : 
php 
$conn = mysql_connect("localhost","root","111")or die(" 连 接 mysql 出 现 错误 "); /连接 mysql 
mysql_select_db("db_database02",$conn); // 连 接 数 据 库 
mysql_query("SET NAMES GBK"): // 设 置 编码 格式 
这 $_POST[sub]){ /通过 POST 方式 传 参 
/sql 语 句 


$sql = "select + from tb_sel where tb_sel name like (96S_POST[text]9) or tb_sel.add like (9%%$_POST[text]%6') or tb_sel.sex like 
(%$ POSTftextlst) or tb seLQQ like(%$ POST[text]96)"; 


$a=$ POSTtext: // 原 参数 
S$b = "<b><font color=#FF0000>".$_POST[text]."</font></b>"; 1/ 描 红 后 的 参数 
> 
<table border="1" bordercolor="#0033CC" cellspacing="0"><tr><td> 用 户 名 </td><td> 性 别 </td><td> 住 址 </td><td>QQ</td></tr> 


while($rst = mysql_fetch_ array($rs)){ /查询 输出 
Srste = Preg_replace("/Sa/".Sb.Srsb: /正则 替换 
/输出 表格 
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echo "<tr><td>".$rste[name]."</td><td>".$rste[sex]."</td><td>".$rste[add]."</td><td>".$rste[QQ]."</td></tr><br>"; 
} 


> 
</table> 


图 秘笈 心 法 


心 法 领悟 121: 使 用 preg_replace0 函 数 的 相关 说 明 。 
preg_ replace0 函 数 的 每 个 参数 〈 除 了 limit) 都 可 以 是 一 个 数组 。 如 果 pattem 和 replacement 都 是 数组 ， 
将 以 其 键 名 在 数组 中 出 现 的 顺序 来 进行 处 理 。 


ga 
实例 122 高 级 
| 


力 实例 说 明 


前 面 的 实例 中 已 经 介绍 了 对 文件 类 型 的 相关 操作 , 本 实例 采用 正则 表达 式 函 数 preg_matchO 实 现 判断 上 传 文 
件 的 类 型 ， 运 行 结果 如 图 2.96 所 示 。 
F: anpp\xanpp\licens [HE ]] 
上 传 为 图 片 类 型 
图 2.96 判断 上 传 文件 的 类 型 


图 关键 技术 
使 用 preg_match0 函 数 进行 正则 表达 式 匹配 ， 详 细 说 明 详 见 实例 110。 
| | 设计 过 程 


创建 index.php 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 利 用 preg_matchO 正 则 表达 式 函 数 将 上 传 的 数据 信息 进行 匹 
配 并 输出 结果 ， 其 代码 如 下 : 


is_POSsTIsubDj{ OR 

iflpreg_match("/jpg/".strtolower($_POST[text)){ /通过 正则 表达 式 函 数 判断 类 型 
echo "上 传 为 图 片 类 型 "; 

Jelse{ 
if(preg_match("/.rar/".strtolower($_POST[text]))){ 

echo "上 传 为 压缩 包 类 型 "; 
echo "其 他 文件 类 型 ": 

} 

} 

> 
图 秘笈 心 法 


心 法 领悟 122: 知识 扩展 。 
本 实例 使 用 的 是 让 ..else.… 语 句 嵌 套 ， 在 结构 上 看 不 是 很 明朗 ， 读 者 可 以 运用 switch0 函 数 改写 此 实例 ， 相 
信 在 系统 运行 效率 上 ， 会 有 所 提高 。 
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实例 123 ck 


趣味 指数 : 会 宣 傅 


图 


用 户 在 购买 电子 商务 网 站 的 商品 时 ， 商 品 一 般 都 是 以 快递 或 邮寄 的 方式 传递 到 用 户 手 中 ， 所 以 如 果 用 户 不 
能 正确 地 填写 邮寄 地 址 或 邮政 编码 , 就 有 可 能 造成 不 必要 的 损失 。 本 实例 通过 正则 表达 式 函 数 preg_match0 验 证 
用 户 提交 的 邮政 编码 格式 是 否 正确 ， 运 行 结果 如 图 2.97 所 示 。 


只 证 邮政 编码 属 式 是 否 正确 
[Ea 


131400 验证 


图 2.97 验证 邮政 编码 是 否 有 效 
图 关键 技术 
(1) preg_matchO 函 数 : 进行 正则 表达 式 匹 配 ， 详 细 参 数 参 见 实例 110。 
(2) 正则 表达 式 : 对 邮政 编码 格式 进行 验证 。 


“09]{6)"; 
图 设计 过 程 


创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 ， 利 用 preg_matchO 正 则 表达 式 函 数 对 文本 框 的 输入 信息 进行 
匹配 并 输出 提示 ， 其 代码 如 下 : 
< 


hp 
这 $_POST[sub]){ /通过 POST 方式 传 参 
require_once("inc.php"): /包含 文件 
if(preg_match("/[0-9]{6}/",trim($_POST['text )){ // 正 则 表达 式 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"): 。“// 显 示 信 息 
jelsef 


show_error(" 信 息 提 示 "…'" 格 式 不 正确 "…"index.php"): 
} 
} 
> 


力 秘笈 心 法 


心 法 领悟 123: 什么 是 邮政 编码 。 

邮政 编码 是 为 了 实现 邮政 分 拒 自 动 化 和 邮政 网 络 数 字 化 设置 的 ， 以 加 快 邮件 邮递 速度 。 目 前 世界 上 有 40 多 
个 国家 先后 实行 邮政 编码 制度 ， 并 以 此 作为 衡量 一 个 国家 通信 技术 和 邮政 服务 水 平 的 标准 之 一 。 各 国 邮 政 编码 
规则 并 不 统一 。 


2.10 数 组 
数组 是 对 大 量 数据 进行 组 织 和 管理 的 有 效 手 段 之 一 ， 通 过 数组 的 强大 功能 ， 可 以 对 大 量 性 质 相同 的 数据 进 
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行 存 储 、 排 序 、 插 入 及 删除 等 操作 ， 从 而 可 以 有 效 地 提高 程序 开发 效率 及 改善 程序 的 编写 方式 。 


起 味 指 才 :请 二 坎 计 


图 实例 说 明 


如 果 只 是 想 保存 几 个 数据 就 没有 必要 和 数据 库 交 互 ， 此 时 ， 可 以 选用 数组 。 本 实例 通过 数组 函数 array0 实 
现 创建 并 输出 数组 ， 运 行 结果 如 图 2.98 所 示 。 
书写 宇 符 素 以 # 号 分 着 创建 禾 组 [输出 数组 


Array ( [0) =» 123 [1] => 456 [2] = 789%y 


图 2.98 输出 数组 


力 关键 技术 


aray0: 新 建 一 个 数组 。 

array array ( [mixed ...] ); 

参数 mixed 的 语法 为 “key=>value”， 多 个 mixed 参数 之 间 用 逗号 隔 开 ， 分 别 定义 了 索引 和 值 。 索 引 可 以 
是 字符 串 或 数字 。 如 果 省 略 了 索引 将 是 目前 最 大 的 整数 索引 +1。 如 果 定 义 了 两 个 完全 一 样 的 索引 ， 则 后 面 一 个 
会 缆 盖 前 一 个 。 数 组 中 的 各 数据 元 素 的 数据 类 型 可 以 不 同 ， 也 可 以 是 数组 类 型 。 当 mixed 是 数组 类 型 时 ， 该 数 
组 就 是 二 维 数组 。 
图 设计 过 程 

创建 index.php 文件 ， 当 单 击 “ 创 建 数组 ”按钮 时 ， 首 先 ,判断 文本 框 信息 是 否 为 空 ， 如 果 为 空 便 输出 提示 ， 
否则 将 文本 框 信息 保 存在 SESSION 变量 之 中 ; 当 单 击 “ 输 出 数组 ”按钮 时 , 首先 , 判断 网 页 中 是 否 存在 SESSION 
变量 ， 如 果 存 在 变量 则 利用 字符 串 拆 分 函数 进行 拆 分 并 打印 输出 ， 其 代码 如 下 : 


if($_POST[sub1){ /1/ 通 过 POST 方式 传 参 
if$_POST[text] — "){ /如 果 文 本 框 为 空 
echo "<script>alert( 您 创建 了 一 个 空 数 组 ):location hre 人 -index.php</script>"， // 输 出 提示 
jelsef 
S$_SESSION['array] = S$_POST[text]: /将 结果 保存 在 SESSION 中 
echo "<script>alert( 创建 数组 成 功 ):location href~'index.php'</script>"; /提示 
} 
} 
这 $_POST[sub2]){ // 通 过 post 方式 传 参 
ifisset($_SESSION['array])){ /如 果 session 存在 
Sarray = explode("#",$_SESSION['array"]); /分 割 字符 串 
print_r(Sarray): /打印 
session _destroy0: /销毁 session 
jelsef 
echo "<script>alert( 请 先 创建 数组 "):location.href='index.php'</script>"; /提示 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 124: 数组 的 重要 作用 。 
数组 是 PHP 基础 语言 中 很 重要 的 一 部 分 ， 灵 活 运用 数组 会 起 到 事半功倍 的 效果 。 


PHP 开发 实战 1200 例 (第 I 卷 ) 


高 级 


i 
实例 125 ee a 


图 实例 说 明 


数组 下 标 默认 是 以 0 为 开始 键 值 的 整 型 数据 ， 如 果 想 取得 数组 元 素 的 个 数 就 要 使 用 count0 函 数 。 本 实例 通 
过 countO 函 数 统计 数组 元 素 个 数 ， 运 行 结果 如 图 2.99 所 示 。 
数组 中 存在 元 素 4 个 


图 2.99 统计 数组 元 素 个 数 


图 关键 技术 


在 PHP 中 ， 应 用 countO 函 数 对 数组 中 的 元 素 个 数 进行 统计 ， 其 语法 如 下 : 

int count ( mixed array [, int mode]) 

参数 说 明 : 

array: 必 选 参数 ， 指 定 被 统计 的 数组 。 

mode: 可 选 参数 ， 其 参数 值 为 COUNT_RECURSIVE (或 1 ) ， 如 选中 此 参数 ， 本 函数 将 递归 地 对 数组 计 
数 。 对 计算 多 维 数组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 是 0。 
图 设计 过 程 

创建 ndex.php 文件 ， 首 先 ， 定 义 数组 变量 并 为 此 变量 赋值 。 然 后 ， 利 用 countO 函 数 输出 数组 元 素 的 个 数 ， 
其 代码 如 下 : 

<?php 

$a = array(1, 精 细 ','asd',asd123); /声明 数组 


echo "数组 中 存在 元 素 ".count($a)." 个 "; 1/ 计算 数组 元 素 个 数 
> 


也 笈 心 法 


心 法 领悟 125: 使 用 count0 函 数 的 注意 事项 。 
如 果 count0 函 数 的 操作 对 象 是 NULL， 那 么 返回 结果 为 0。count0 函 数 对 没有 初始 化 的 变量 返回 0， 但 对 于 空 
的 数组 也 会 返回 0。 如 果 要 判断 变量 是 否 初始 化 ， 则 可 以 应 用 isset0 函 数 。 另 外 ，countO 函 数 不 能 识别 无 限 递归 。 


i | 


力 实例 说 明 


数组 元 素 的 个 数 和 元 素 值 是 可 以 改变 的 。 本 实例 通过 数组 函数 array_push0 向 数组 中 添加 元 素 ， 运行 结果 如 
图 2.100 所 示 。 


| 原 数 组 :Arfay (10] => 工 国 => 精细 加 => asd [3] => asd123) 
添加 元 素 后 的 数组 上 Array ( [0] => 1 [四 => 精细 [2) => asd 国 => asd123 [村 当 
哈哈 ) 


图 2.100 向 数组 中 添加 元 素 


第 2 章 PHP 基础 
图 关键 技术 


在 PHP 中 ， 向 数组 中 添加 元 素 使 用 ] amay_push0 卫 数 ， 其 语法 如 下 : 
int array_push ( array array, mixed var [, mixed 

参数 说 明 : 

array array: 原 数组 。 

mixed var: 压 入 的 数据 元 素 。 

该 函数 将 array 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 array 的 末尾 。 


图 设计 过 程 
创建 index.php 文件 ， 首 先 ， 定 义 数组 变量 ， 并 为 数组 变量 赋值 。 然 后 ， 利 用 amray_pushO 函 数 向 数组 中 添 
加 元 素 并 打印 数组 输出 信息 ， 其 代码 如 下 : 


<?php 
$a= Ey 精细 "asd','asd123"); /声明 一 个 数组 
echo " 原 数 
print_r($a)." ee /| 输出 数组 
array_push($a, 哈 哈 ); /向 数组 末尾 添加 元 素 
echo "<br> 添 加 元 素 后 的 数组 :"; 
print r($a); /打印 添加 元 素 后 的 数组 
?> 
秘笈 心 法 


心 法 领悟 126: 使 用 array_push0 函 数 的 相关 说 明 。 
如 果 用 array_push0 函 数 单纯 地 给 数组 增加 一 个 单元 ， 不 如 选用 $array[]=， 因 为 这 样 没有 调用 函数 的 额外 
负担 。 


趣味 指数 : 傅 帘 商 窗 | 


力 实例 说 明 


创建 数组 时 ， 由 于 疏 忽 将 元 素 内 容 书 写 错误 ， 更 改 错误 的 元 素 内 容 可 以 通过 数组 键 值 实 现 。 本 实例 通过 数 


组 下 标 〈 键 值 ) 实现 将 数组 中 指定 索引 位 置 的 元 素 替 换 ， 运 行 结果 如 图 2.101 所 示 。 


原 数组 元 来 Array( [0] => 1 [1] => 精细 [2] => asd 本 => asd123) 
指定 索引 元 素 营 挽 后 的 数组 : Array ( [0] => 工作 二 > 精细 四 => 经 济 四 => 
asd123 ) 

键 值 1 的 元 素 发 生 更 改 


图 2.101 将 数组 中 指定 索引 位 置 的 元 素 替换 


图 关键 技术 


PHP 数字 索引 由 数字 组 成 ， 下 标 从 0 开始 ， 数 值 索 引 一 般 表 示 数 组 元 素 在 数组 中 的 位 置 ， 数 字 索 引 数 组 默 
认 索 引 值 从 数字 0 开始 ， 不 需要 特别 的 指定 ，PHP 会 自动 为 索引 数组 的 键 名 赋 一 个 整数 值 ， 然 后 从 这 个 值 开 始 
自动 增 量 ， 当 然 ， 也 可 以 指定 某 个 位 置 开 始 保存 数据 。 


图 设计 过 程 
创建 index.php 文件 ， 定 义 数组 变量 并 通过 数组 下 标 输出 元 素 ， 其 代码 如 下 : 
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echo " 原 数组 元 素 : "; 

$a 二 array(1, 和 精细 ','asd','asd123); // 定 义 数 组 

Print r($a): /打印 数组 

echo "<br> 指 定 索引 元 素 蔡 换 后 的 数组 : 

$a[2] = // 恨 据 数 组 下 标 更 改元 素 
Print_r($a): // 打 印 更 改 后 的 数组 
echo "<br> 键 值 2 的 元 素 发 生 更 改 "; 


> 


图 秘笈 心 法 

心 法 领悟 127: 使 用 数组 键 值 的 注意 事项 。 

当 使 用 “组 名 称 [ 键 值 ]” 这 样 的 格式 时 ， 要 注意 数组 键 值 是 从 0 开始 的 ， 所 以 本 例 中 更 改 键 值 为 2 的 元 素 ， 
其 实 是 数组 中 的 第 3 个 元 素 。 


Re ey 
元 素 高 级 
守 休 | 
实例 128 he i 
图 实例 说 明 
在 数组 元 素 比较 多 的 情况 下 , 想 要 取得 数组 中 的 最 后 一 个 元 素 可 以 通过 一 一 
获取 数组 中 最 后 一 个 元 素 是 ; i 


先 计算 元 素 的 个 数 再 通过 下 标 取得 ,还 可 以 通过 函数 取得 。 本 实例 通过 数组 
函数 array_ pop0 实 现 获 取 数 组 中 的 最 后 一 个 元 素 ,运行 结果 如 图 2.102 所 示 。 图 2 10? 获取 数组 中 最 后 一 个 元 素 


图 关键 技术 
使 用 array_pop0 函 数 获取 并 返回 array 数组 的 最 后 一 个 单元 ， 并 将 数组 array 的 长 度 减 1， 其 语法 如 下 : 
mixed array_pop ( array array); 
图 设计 过 程 
创建 ndex.php 文件 。 首先 ， 定义 数 组 变量 $a 并 为 此 数组 变量 赋值 。 然 后 ,利用 函数 array_pop0 弹 出 数组 中 
的 -个 元 素 并 输出 结果 ， 其 代码 如 下 : 


Es 一 amray(avbvcsdvevf ,gh i); /声明 数组 
echo "获取 数组 中 最 后 一 个 元 素 是 :".array_pop($a); /返回 数组 中 最 后 一 个 元 素 
> 


图 秘笈 心 法 


心 法 领悟 128: 使 用 array_pop0 函 数 的 相关 说 明 。 
在 使 用 array_pop0 函 数 时 ， 数 组 中 最 后 一 个 元 素 是 被 取出 而 不 是 被 复制 ， 即 每 次 使 用 此 函数 ， 数 组 元 素 就 
会 减少 一 个 。 如 果 数 组 为 室 〈 或 者 不 是 数组 ) 将 返回 NULL。 


国 实例 说 明 


在 数组 中 键 值 是 唯一 的 ， 但 是 元 素 的 值 是 可 以 重复 的 。 想 要 删除 数组 元 素 中 重复 的 值 可 以 使 用 函数 
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array_Uunique0。 本 实例 是 通过 数组 函数 array_unique0 去 除数 组 中 的 重复 元 素 值 ， 运 行 结果 如 图 2.103 所 示 。 
后 天 组 元 素 为 5 Array ( [0] =>a 四 = bj[2] 仿 Sa) => d [4 => a [5] => flgl 


=>a 团 =>hlaj=>a) 
去 除 重复 项 后 的 数组 为 : Array ( [ => a [1]=> 5[3] => d [9 =>f[7] => hy) 


2.103 ”去 除数 组 中 的 重复 元 素 


图 关键 技术 
在 PHP 中 ， 通 过 array unique0 函 数 去 除数 组 中 的 重复 元 素 ， 其 语法 如 下 : 


array array_unique ( array array); 


参数 array 为 指定 参数 的 数组 ， 其 返回 值 为 一 个 没有 重复 元 素 的 新 数组 。 
图 设计 过 程 
创建 index.php 文件 。 首 先 ， 创 建 数 组 变量 $a 并 为 其 赋值 。 然 后 ， 利 用 array_unique0 去 除数 组 中 的 重复 元 


素 值 。 最 后 ， 打 印 数组 ， 其 代码 如 下 : 
<?php 
$a = amray(avb'a, davf ,a',h',a); /定义 数组 
echo " 原 数组 元 素 为 : 
print_r($a); /打印 数组 
echo "<br> 去 除 重复 项 后 的 数组 为 :"; 
print_r(array_unique($a)); /输出 去 除 重复 项 的 数组 


> 
图 秘笈 心 法 
心 法 领悟 129: 使 用 array_unique0 函 数 的 原理 。 
使 用 array_unique0 函 数 的 原理 是 先 将 值 作为 字符 串 排序 ， 然 后 对 每 个 值 只 保留 第 一 个 遇 到 的 键 名 ， 而 忽略 
所 有 后 面 的 键 名 。 但 这 并 不 意味 着 在 未 排序 的 数组 中 同一 个 值 的 第 一 个 出 现 的 键 名 会 被 保留 。 
高 级 
趣味 指数 : 会 依依 请 | 


力 实例 说 明 


实例 109 介绍 了 字符 串 与 数字 之 间 的 转换 ， 下 面 来 介绍 字符 串 与 数组 之 间 的 转换 。 本 实例 是 通过 强制 类 型 
转换 实现 字符 串 与 数组 的 转换 的 ， 运 行 结果 如 图 2.104 所 示 。 


字符 串 转换 为 数组 : Array ( [0] = > 123 ) 


数组 转 埃 为 字符 惠 : Array 


图 2.104 字符 串 与 数组 的 转换 


图 关键 技术 


虽然 PHP 是 弱 类 型 语言 ， 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 ， 在 
变量 前 加 上 用 括号 括 起 来 的 类 型 名 称 即 可 。 人 允许 转换 的 类 型 如 表 2.7 所 示 。 
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表 2.7 类 型 强制 转换 


转换 操作 符 转换 类 型 举例 


(boolean) | 转换 成 布尔 型 (boolean)$num、(boolean)$str 
(string) | 转换 成 字符 型 (string)$boo、(string)$flo 
(integer) | 转换 成 整 型 (integer)$boo、(integen)$str 
(float) | 转换 成 浮 点 型 (floaD)$str、 (float)$str 

(amay) | 转换 成 数组 (array)$str 


转换 成 对 象 


object) $str 


图 设计 过 程 


创建 index.php 文件 。 首先 ， 定 义 数组 变量 并 为 此 变量 赋值 ， 然 后 ， 利 用 强制 类 型 转换 的 方法 将 字符 串 类 型 
转换 为 数组 类 型 ， 其 代码 如 下 : 


<?php 
$a="123"; /声明 字符 串 变量 
$b= (array)$a; // 将 字符 串 转换 为 数组 
echo "字符 串 转换 为 数组 :"; 
print r(Sb): 1/ 打印 数组 
echo “<hr>"; 
Sc= i /定义 数组 
$d = (strin // 将 数组 转换 为 字符 串 
echo" 数组 轩 扫 为 字符 和: Ww 
echo Sd; // 输 出 字符 串 

> 

秘笈 心 法 


心 法 领悟 130: 将 数组 强制 转换 成 字符 串 的 注意 事项 。 
将 数组 强制 转换 成 字符 串 时 ， 数 组 将 被 转换 成 字符 串 "Array"， 因 此 无 法 通过 echo0 或 者 printO 函 数 来 输出 
数组 的 内 容 


实例 131 


图 实例 说 明 
本 实例 通过 shuffle0 函 数 实现 对 数组 元 素 进 行 随机 排序 ， 运 行 结果 如 图 2.105 所 示 。 
原 数组 元 素 星 序 为 '; 经 济 a b 123 asd 
经 随机 排序 后 8 既 济 asd 123 b 
图 2.105 ”对 数组 元 素 进行 随机 排序 
图 关键 技术 
在 PHP 中 ， 将 数组 元 素 进行 随机 排序 使 用 shuffle0 函 数 ， 其 语法 如 下 : 
void shuffle ( array array): 
使 用 该 函数 将 数组 打 乱 ， 随 机 排序 。 
图 设计 过 程 


新 建 index.php 文件 。 首 先 ， 定 义 数组 变量 ， 利 用 srandO 函 数 播 下 随机 数 发 生 器 种 子 。 然 后 ， 利 用 shuffle0 
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函数 将 数组 打 乱 。 最 后 ， 输 出 数组 元 素 ， 其 代码 如 下 : 


<?php 

Snumbers = amray( 经 济 …avb.123vasd]: 

echo " 原 数组 元 素 顺序 为 : 经 济 ab 123 asd"; 

srand ((float)microtimeO*1000000): 

shuffle (Snumbers): 

echo "<br> 经 随机 排序 后 : 

while (list ( SnumbeD = re { 
echo "Snumber "; 


} 


> 


国 秘笈 心 法 


心 法 领悟 131: 使 用 shuffle0 函 数 的 注意 事项 。 
在 使 用 shuffle0 函 数 将 数组 打 乱 时 ， 必 须 用 srand0 函 数 播 下 本 函数 的 随机 数 发 生 器 的 种 子 ， 否 则 得 不 到 预 
期 结果 。 


图 实例 说 明 
可 以 把 随机 抽取 数组 中 的 元 素 看 成 一 个 彩票 抽奖 的 大 摇 箱 ， 在 原理 上 两 者 是 没什么 区 别 的 ， 但 是 彩票 抽奖 

的 大 摇 箱 可 能 存在 一 点 点 的 偶然 性 ， 例 如 大 摇 箱 里 的 球 弹力 不 同等 。 本 实例 通过 随机 函数 rand0 实 现 随机 抽取 

数组 中 的 元 素 ， 运 行 结 果 如 图 2.106 所 示 。 

| 数组 : Atray (loj => 经济 [有 =>a[2] => bj=>123 团 =>asd) 

随机 取得 数组 的 元 素 是 ; b 


图 2.106 随机 抽取 数组 中 元 素 


图 关键 技术 


应 用 randO 函 数 获取 随机 数值 ， 并 将 随机 数值 指向 数组 下 标 从 而 实现 随机 获取 指定 元 素 的 值 。randO 函 数 的 
语法 如 下 : 

intrand ( [int min, int max]): 

参数 说 明 : 

min: 随机 数 的 最 小 值 。 

max: 随机 数 的 最 大 值 。 


四 设计 过 程 


创建 PHP 脚本。 首先， 定义 数组 变量 并 为 数组 变量 赋值 。 然 后 ， 利 用 rand0 函 数 获取 0~4 中 的 一 个 随机 数 ， 


并 将 此 随机 数 赋 给 数组 变量 作为 数组 变量 的 键 值 。 最 后 ， 输 出 此 数组 变量 ， 其 代码 如 下 : 
<?php 
$numbers = array( 经 济 '"avb'"123'"asd): /定义 数组 
echo "数组 : "; 
print_r(Snumbers): 
Srand = rand(0.4): // 创 建 一 个 0~4 的 随机 数字 
echo "<br> 随 机 取得 数组 的 元 素 是 : ".Snumbers[Srand]: 。“// 将 随机 数字 作为 键 值 获取 数组 元 素 
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图 秘笈 心 法 


心 法 领悟 132: 随机 函数 rand0 的 相关 说 明 。 
在 使 用 随机 函数 rand0 时 ， 如 果 没 有 提供 可 选 参数 min 和 max，rand0 返 回 0-RAND_MAX 之 间 的 伪 随 机 
数 。 例 如 想得到 10~30 (包括 10 和 30) 之 间 的 随机 数 ， 使 用 rand(5, 15)。 


hohode | 


图 实例 说 明 
二 维 数组 可 以 简单 理解 为 数组 元 素 中 还 包含 一 个 数组 。MySQL 图 形 化 管理 工具 phpMyAdmin 中 存储 的 每 

个 数据 表 其 实 就 是 一 个 二 维 数组 。 本 实例 实现 二 维 数组 中 数据 的 输出 ， 运 行 结果 如 图 2.107 所 示 。 

输出 二 维 故 弓 $a Array ( => Amay ( [0] 2>a[l] =>b)[2] => Array ([0] =S ¢ 


=>d) [3> Aray (lg => ee=> 人 
输出 一 维 效 组 $a 键 秆 为 1 元 素 $a[l1] : Array ( [Q] => a [1] => b) 


图 2.107 二 维 数组 的 输出 


图 关键 技术 


如 果 创 建 的 数组 中 的 元 素 的 值 都 是 变量 ， 此 数组 称 为 一 维 数组 ， 如 果 创 建 的 数组 的 元 素 值 仍然 是 数组 ， 那 
么 就 称 为 二 维 数组 。 也 就 是 说 ， 一 个 数组 的 元 素 如 果 仍 是 一 个 一 维 数组 ， 则 称 这 个 数组 是 二 维 数组 。 
力 设计 过 程 
创建 ndex.php 文件 。 首 先 ， 定 义 二 维 数组 变量 $a 并 为 此 变量 赋值 ， 然 后 ， 利 用 print_r0 函 数 实现 二 维 数组 
的 输出 ， 其 代码 如 下 : 
<?php 
echo 输出 二 维 数组 Sa: “ 
$a= ee vb).2=>armray(c'd).3=>array 人 ev /创建 一 个 二 维 数组 
二 二 维 数组 $a 键 值 为 1 元 素 Sa[1]: 


print_r($a[1]); /打印 二 维 数组 键 值 为 1 的 元 素 
> 


图 秘笈 心 法 


心 法 领悟 133: 对 PHP 中 数组 的 理解 。 

PHP 中 的 数组 实际 上 是 一 个 有 序 图 。 该 图 是 一 种 把 values 映射 到 keys 的 类 型 ， 此 类 型 在 很 多 方面 做 了 
优化 ， 因 此 可 以 把 它 当成 真正 的 数组 来 使 用 ， 或 列表 〈 矢 量 ) 、 散 列表 (是 图 的 一 种 实现 ) 、 字 典 、 集 合 、 栈 、 
队列 以 及 更 多 可 能 性 。 因 为 可 以 用 另 一 个 PHP 数组 作为 值 ， 也 可 以 很 容易 地 模拟 树 。 


高 级 
人 hf? 页 


力 实例 说 明 


每 一 个 数组 元 素 都 是 由 键 名 和 值 两 部 分 组 成 的 。 想 要 获取 它们 可 以 通过 循环 来 实现 。 本 实例 通过 foreachO 
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语句 获取 数组 当前 的 键 名 和 值 ， 运 行 结果 如 图 2.108 所 示 。 


[ETIE 
值 为 :123 你 好 mineri 


2.108 ”获取 键 名 值 


图 关键 技术 


数组 中 的 每 个 实例 都 包含 两 项 : 键 和 值 。 其 中 键 可 以 是 数字 、 字 符 串 或 者 数字 和 字符 串 的 组 合 ， 用 于 标识 
数组 中 相应 的 值 ， 而 值 被 称 为 数组 中 的 元 素 ， 可 以 定义 为 任意 数据 类 型 ， 甚 至 是 混合 类 型 ， 最 终 通过 键 来 获取 
相应 的 值 。 
图 设计 过 程 

新 建 ndex.php 文件 。 首先 , 定义 数组 变量 $array 并 且 为 其 赋值 。 当 单 击 “ 获 取 键 名 ”按钮 时 ， 利 用 foreachO 


语句 遍历 数组 并 输出 所 有 元 素 的 键 值 ， 当 单 击 “ 获 取 值 ”按钮 时 ， 同 样 通过 foreachO 语 名 获取 数 组 元 素 的 value 
值 并 且 输 出 ， 其 代码 如 下 : 
< 


Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 ","456"=>"mingri"); // 定 义 数组 
if($_POST[sub){ /通过 POST 方式 传 参 
echo " 键 名 为 :"; 
foreach($array as $key => $value){ // 遍 历数 组 
echo $key."&nbsp:&nbsp:&nbsp:S&nbsp:": /输出 键 值 
} 
这 $_POST[subl]){ /通过 POST 方式 传 参 
echo " 值 为 :"; 
foreach($array as $key => $value){ /1/ 议 历数 组 
echo $value."&nbsp:é&-nbsp;é&nbsp;énbsp;"; / 脸 出 值 
} 
} 
> 
秘笈 心 法 


心 法 领悟 134: 使 用 foreach0 语 句 的 注意 事项 。 
foreach0 语 句 只 能 用 于 数组 。 


趣味 指数 : 帘 本 页 窗 ， 


力 实例 说 明 


PHP 大 型 的 程序 开发 往往 把 程序 员 弄 的 焦头烂额 ， 有 时 程序 员 不 确定 自己 定义 的 数组 中 是 否 存在 需要 的 元 
素 。 本 实例 通过 array_key_exists0 函 数 检测 数组 中 是 否 存 在 某 个 值 ， 运 行 结果 如 图 2.109 所 示 。 
EE] 


来 自 http://1localhost 的 页 面 说 : 


at 


Cj 


图 2.109 检测 数组 中 是 否 存在 某 元 素 
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图 关键 技术 
在 PHP 中， 检测 数组 中 是 否 存在 某 个 值 ， 使 用 amray key exists0 函 数 ， 其 语法 如 下 : 


bool array_key_exists ( mixed key. array search ); 

参数 说 明 : 

Imixed key: 检测 元 素 。 

array search: 源 数组 。 

该 函数 检查 给 定 的 键 名 或 索引 是 否 存在 于 数组 中 。 


图 设计 过 程 
新 建 index.php 文件 ， 定 义 数 组 变量 $array 并 为 其 赋值 ， 当 单 击 “ 检 测 ” 按 钮 时 ， 利 用 array_key_exists0 函 
数 判 断 接收 到 的 文本 框 信息 是 否 存在 于 指定 的 数组 元 素 中 , 并 且 根 据 返回 值 给 出 相应 的 提示 信息 ， 其 代码 如 下 : 
<?pl 


hp 
Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 "."456"=>"mingri"); /定义 数组 
这 $_POST[sub]){ /通过 POST 方式 传 参 
这 array_key_exists($_POST[text],Sarray)){ /检测 是 否 存在 元 素 
echo "<script>alert( 数 组 中 存在 此 元 素 );</script>": /提示 
jelse{ 


echo "<script>alert( 数 组 中 不 存在 此 元 素 ):</script>": /提示 
} 
} 
> 


图 秘笈 心 法 


心 法 领悟 135: array_key_exists0 函 数 的 相关 说 明 。 
array_key_exists0 函 数 在 给 定 的 key 存在 于 数组 中 时 返回 TRUE，key 可 以 是 任何 能 作为 数组 索引 的 值 。 
array_key_exists() 也 可 用 于 对 象 。 


图 实例 说 明 
本 实例 通过 current0 函 数 获取 数组 中 的 当前 单元 ， 运 行 结 果 如 图 2.110 所 示 。 
(EEE 
PF 范例 宝典 
图 2.110 获取 数组 中 的 当前 单元 
图 关键 技术 
current0 函 数 的 主要 功能 是 返回 数组 中 的 当前 单元 ， 其 语法 如 下 : 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 。 首先 , 定义 数组 变量 并 为 其 赋值 ， 当 单 击 “ 获 取 单 元 ”按钮 时 , 通过 函数 currentO 
获取 数组 当前 元 素 ， 其 代码 如 下 : 
php 


$array =array(" 编 程 "=>"PHP 范例 宝典 ","soft"=>" 你 好 "."456"=>"mingri"); /定义 数组 
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if($_POST[sub) { 1/ 通过 POST 方式 传 参 
echo current(Sarray): /获取 当前 数组 中 的 单元 
¥ 
2 
(2) 将 该 文件 存储 于 \MR\02\136\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.110 所 示 。 
图 秘笈 心 法 


心 法 领悟 136: 使 用 currentO 函 数 的 相关 说 明 。 

current0 函 数 返 回 当前 被 内 部 指针 指向 的 数组 单元 的 值 ， 并 不 移动 指针 。 如 果 内 部 指针 指向 超出 了 单元 列表 
的 末端 ，current0 返 回 FALSE。 如 果 数 组 包含 有 空 的 单元 (0 或者， 空 字符 串 ) ， 则 本 函数 在 碰 到 这 个 单元 时 
也 返回 FALSE。 


高 级 


实例 137 趣味 指数 : 帘 窗 窗帘 | 


图 实例 说 明 


通过 rand0 函 数 可 以 随机 抽取 数组 中 的 元 素 。 下 面 再 通过 另外 一 个 函数 array_rand0 实 现 从 数组 中 随机 取出 
元 素 ， 运 行 结果 如 图 2.111 所 示 。 


获取 随机 元 寄 ，PHP 季 例 宝典 


图 2.111 从 数组 中 随机 取出 元 素 


图 关键 技术 


当 用 户 想 从 数组 中 取出 一 个 或 多 个 单元 时 ， 使 用 array_rand0 函 数 是 非常 有 用 的 ， 它 与 rand0 函 数 获取 随机 
数组 元 素 的 原理 大 同 小 异 ， 其 语法 如 下 : 

mixed array_rand ( array input [, int num req] ); 

参数 说 明 : 

array input: 传 入 的 数组 。 

int num req: 可 选 参 数 ， 定 义 输出 数组 元 素 的 个 数 。 


设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数组 变量 $array 并 为 其 赋值 ， 当 单 击 “ 获 取 单元 ”按钮 时 ， 通过 函数 
array_rand0) 获 取 数 组 中 的 随机 元 素 值 ， 其 代码 如 下 : 


<?php 
Saray =array(" 编 程 "=>"PHP 范例 宝典 "."soft"=>" 明 日 科技 "456"=>"mingri"); /定义 数组 
这 $_POST[sub]){ /通过 POST 方式 传 参 
Srand keys = array_rand($array. 1): /获取 数组 的 随机 键 值 
echo "获取 随机 元 素 : ".Sarray[Srand keys] ; // 输 出 随机 元 素 值 
中 
> 
(2) 将 该 文件 存储 于 \MR\02\137\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.111 所 示 。 
图 秘笈 心 法 


心 法 领悟 137: 使 用 array_rand0 函 数 的 相关 说 明 。 
aray_Iand0 函 数 在 想 从 数组 中 取出 一 个 或 多 个 随机 的 元 素 时 相当 有 用 。 它 接受 $array 作为 输入 数组 和 一 个 
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可 选 的 参数 num_ req， 指 明 想 取出 多 少 个 元 素 。 如 果 没 有 指定 ， 默 认为 1。 如 果 只 取出 一 个 ，array_rand() 返回 
一 个 随机 元 素 的 键 名 ， 否 则 就 返回 一 个 包含 随机 键 名 的 数组 。 这 样 用 户 就 可 以 随机 从 数组 中 取出 键 名 和 值 。 


实例 138 


图 实例 说 明 
数组 与 数组 之 间 是 彼此 独立 的 ， 但 是 两 个 数组 可 以 合并 到 一 起 成 为 一 个 新 数组 。 本 实例 通过 数组 函数 
array_merge() 实 现 合 并 数组 ， 运 行 结果 如 图 2.112 所 示 。 


数组 1，Array ( pl = PHP 范 例 宝典 [soft] = 明日 
科技 [456]%=> 而 meri 


数组 2，Array (pf9]> PHP 编 程 [1] =》 JAVA 编程 上 2 
=》 CH 编程 [3] =》 ASP. 全 1? 编程 ) 


Fi ( [编程 ] >》PHP 范 例 宝典 [Soft] = 


明日 科技 [0]6=> wineri [1] => Li [2] =>JJAVA 编 
程 [3] => Ck 编程 [4] => ASP. NET 编 程 ) 


2.112 合并 数组 


图 关键 技术 
数组 的 合并 应 用 的 是 array_merge0 函 数 ， 其 语法 如 下 : 


array array_merge ( array array1 [, array array2 [, array …]] ); 
参数 说 明 : 

array arrayl: 数组 1。 

alray array2: 数组 2。 


力 设计 过 程 
新 建 index.php 文件 ,首先 ,定义 两 个 数组 变量 并 为 其 赋值 。 当 单 击 “ 合 并 数组 ”按钮 时 ,利用 函数 array_mergeO 
Se, 并 打印 合并 后 的 数组 ， 其 代码 如 下 : 


De 范例 宝典 ","soft"=>" 明 日 科技 ","456"=>"mingri"); // 定 义 数组 1. 
echo "数组 1: "; 
ee /打印 数组 


Sarr= et 编程 "JAVA 编程 ","C# 编 程 "."ASP.NET 编程 "); /定义 数组 2. 

echo" 数 组 2: "; 

print_r($am); /打印 数组 

echo "<br><br>"; 

这 $_ POST[sub]){ /通过 POST 方式 传 参 
echo "合并 后 的 数组 ": 
print_r(array_merge(Sarray.SarD): /打印 合并 后 的 数组 


上 
> 


图 秘笈 心 法 


心 法 领悟 138: 使 用 array_merge0 函 数 的 相关 说 明 。 
aray_Imerge0 函 数 将 一 个 或 多 个 数组 的 单元 合并 起 来 ， 一 个 数组 中 的 值 附加 在 前 一 个 数组 的 后 面 ， 返 回 作 
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为 结果 的 数组 。 如 果 输 入 的 数组 中 有 相同 的 字符 串 键 名 ， 则 该 键 名 后 面 的 值 将 覆盖 前 一 个 值 。 然 而 ， 如 果 数 组 
包含 数字 键 名 ， 后 面 的 值 将 不 会 覆盖 原来 的 值 ， 而 是 附加 到 后 面 。 如 果 只 给 了 一 个 数组 并 且 该 数组 是 数字 索引 
的 ， 则 键 名 会 以 连续 方式 重新 索引 。 


高 级 


实例 139 he Pe 


图 实例 说 明 
存在 数组 的 合并 函数 当然 也 就 存在 数组 的 拆 分 函数 。 本 实例 通过 函数 amray_chunk0 实 现 数组 的 拆 分 ， 运 行 


结果 如 图 2.113 所 示 。 


拆 分 数组 


原 数 组 ， Arréy A [0] 过 FP 编程 [1] =》JAVA 编 程 A[2] 
> C4 编程 [3] FASE. NET 编 程 


拆 分 后 的 数组 ，Aryay、( 0] a> Array ( [0] = BE 纺 程 
[1] = TAN A‘ (=) Rray ( [0] = ch 编程 [ae 
-=ASPaNET: 


图 2.113 ” 拆 分 数组 


力 关键 技术 


array_chunkO 函 数 可 将 一 个 数组 分 割 成 多 个 ， 其 原理 是 将 原 有 数据 根据 传递 的 参数 不 同 分 割 成 多 个 二 维 数 
组 。array_chunk0 函 数 的 语法 如 下 : 

array array_chunk ( array input, int size [, bool preserve_keys] ); 

参数 说 明 : 

amay input: 源 数组 。 

int size: 分 割 成 指定 数量 的 数组 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数 组 变量 并 为 其 赋值 ， 当 单 击 “ 拆 分 数组 ”按钮 时 ， 打 印 被 拆 分 后 
的 数组 ， 其 代码 如 下 : 
<?php 
Sarr= ee 编程 ""JAVA 编程 "."C# 编 程 "."ASP.NET 编程 "); // 定 义 数组 
Prt I($arm); /打印 数组 
echo "<br><br>"; 
echo " 拆 分 后 的 数组 : 
这 $_POST[sub]){ /通过 POST 方式 传 参 
Print_r(aray_chunk($arr.2)."<br>"; /| 拆 分 数组 


} 

> 

(2) 将 该 文件 存储 于 \MR\02\139\ 文 件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.113 所 示 。 
图 秘笈 心 法 


心 法 领悟 139: 使 用 array_chunkO 函 数 的 注意 事项 。 
使 用 array_chunkO 函 数 拆 分 的 数组 ， 最 后 一 个 数组 的 单元 数目 可 能 会 少 几 个 。 
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高 级 | 
| 二 二 页 二 ol 


力 实例 说 明 
通过 for0 语 句 可 以 遍历 数组 ， 下 面 通过 另外 一 种 方法 来 遍历 数组 。 本 实例 通过 list0 和 each0 函 数 实现 遍历 
数组 ， 运 行 结果 如 图 2.114 所 示 。 
这 历数 组 
Array ( [1],=> PHP 编程 [value] => FHP 编程,[0] => 0 [key] => 0 ) 
Array ( []] =X JAVA 编程 [value] => JAVA 编 程 [0] 1 {key] ,六 ， 
) Array ( [站 -= CH 编程 [value] => Ch 编程 [0] =z> 2 [key] = 
Array ( [1] =>phSPSNEI 编 程 ivalue] => ASP. IET 纺 和 [Qly=28 dr 


=>3 


图 2.114 遍历 数组 


力 关键 技术 


遍历 数组 的 方法 有 很 多 ， 除 了 使 用 foreachO 语 名 外， 还 可 以 通过 list0 和 each0 函 数 配合 使 用 实现 ， 其 相关 
语法 如 下 : 

list0 函 数 ， 把 数组 中 的 值 赋 给 一 些 变量 。 与 array0 函 数 类 似 ， 其 不 是 真正 的 函数 ， 而 是 语言 结构 。list0 函 
数 仅 能 用 于 数字 索引 的 数组 ， 且 数字 索引 从 0 开始 ， 其 语法 如 下 : 


Void list ( mixed ...) 

参数 mixed 为 被 赋值 的 变量 名 称 。 

eachO 函 数 ， 返 回 数组 中 当前 指针 位 置 的 键 名 和 对 应 的 值 ， 并 向 前 移动 数组 指针 。 键 值 对 被 返回 为 4 个 单 
元 的 数组 ， 键 名 为 0、1、key 和 value。 单 元 0 和 key 包含 有 数组 单元 的 键 名 ，1 和 value 包含 有 数据 ， 其 语法 
如 下 : 

array each ( array array) 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 遍 历数 组 ”按钮 时 ， 首 先 ， 定 义 数 组 变量 并 为 其 赋值 ， 然 后 ， 通 过 listO 
和 each0 函 数 实现 数组 遍历 ， 并 输出 结果 ， 其 代码 如 下 : 


if($_POST[sub){ // 通 过 POST 方式 传 参 
S$foo = array("PHP 编程 "."JAVA 编程 "."C# 编 程 "."ASP.NET 编程 "): // 定 义 数组 
for($a = 0:$a < count($foo):Sat+){ /定义 循环 
Print_r(list(S$name. $value)=each($fo0)): /打印 数组 
} 
} 
> 
(2) 将 该 文件 存储 于 \MRM\02\140 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.114 所 示 。 
力 秘笈 心 法 


心 法 领悟 140: 使 用 list0 和 each0 函 数 的 注意 事项 。 
listO 函 数 只 能 用 于 数字 索引 的 数组 。 如 果 内 部 指针 越过 了 数组 的 末端 ， 则 each0 函 数 返回 FALSE。 
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2.11 日 期 和 时 间 


对 日 期 和 时 间 进 行 操作 的 程序 无 处 不 在 ， 特 别 是 在 基于 Web 的 应 用 程序 中 ， 如 表单 提交 的 时 间 、 用 户 登 录 
的 时 间 、 数 据 库 中 数据 的 更 新 和 删除 的 时 间 等 。 想 要 记录 这 些 操作 执行 的 时 刻 ， 就 需要 通过 日 期 和 时 间 来 完成 。 
日 期 和 时 间 在 人 们 的 生活 中 必 不 可 少 ， 同 样 ， 在 互联 网 中 也 是 非常 重要 的 。 


图 实例 说 明 


系统 的 当前 时 间 受 时 区 限制 ， 默 认 情 况 下 是 格林 威 治 时 间 。 用 户 正确 取得 本 地 时 间 是 很 重要 的 。 本 实例 通 
过 date0 函 数 获取 系统 的 当前 时 间 ， 运 行 结果 如 图 2.115 所 示 。 


中 国立 [地 区 时 间 


10:03:34 


图 2.115 设置 系统 的 当前 时 间 


图 关键 技术 


因为 在 PHP 语言 中 , 日 期 、 时间 函 数 依赖 于 服务 器 的 地 区 设置 , 而 PHP 默认 设置 的 是 标准 的 格林 威 治 时 间 
( 即 采用 的 是 零 时 区 ) ， 所 以 ， 如 果 没 有 对 PHP 的 时 区 进行 设置 ， 那 么 使 用 日 期 、 时 间 函 数 获取 的 将 是 英国 伦 
敦 本 地 时 间 〈 即 零 时 区 的 时 间 〉。 

这 也 就 是 为 什么 要 对 PHP 的 时 区 进行 设置 的 原因 ， 因为 如 果 不 设置 正确 的 时 区 ,那么 PHP 的 日 期 、 时 间 函 
数 就 获取 不 到 正确 的 当地 时 间 。 例 如 ， 以 东 八 区 为 例 ， 如 果 当 地 使 用 的 是 北京 时 间 ， 那 么 如 果 没 有 对 PHP 的 时 
区 进行 设置 ， 获 取 的 时 间 就 将 比 北京 时 间 少 8 个 小 时 。 

更 改 PHP 语言 中 的 时 区 设置 如 下 有 两 种 方法 。 

(1) 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone =” 选 项 ， 去 掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当 
地 所 在 时 区 使 用 的 时 间 。 修 改 内 容 如 图 2.116 所 示 。 

例如 ， 如 果 当 地 所 在 时 区 为 东 八 区 ， 那 么 就 可 以 设置 “date.timezone =” 的 值 为 PRC、Asia/Hong_Kong、 
Asia/Shanghai (上 海 ) 或 者 a (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


ETTZ EE 0x| 
Er 


Coate] 

; Defines the default tinezone used by the 
date Functions 

; http://php net/date-tinezone 


图 2.116 设置 PHP 的 时 区 


设置 完成 后 ， 保 存 文件 ， 重 新 启动 Apache 服务 器 。 
(2) 在 应 用 程序 中 ,在 日 期 、 时 间 函 数 之 前 使 用 date_default timezone _setO 函 数 就 可 以 完成 对 时 区 的 设置 。 
date_default_timezone set(0) 函 数 的 语法 如 下 : 


date_default_timezone_set(timezone): 


参数 timezone 为 PHP 可 识别 的 时 区 名 称 ， 如 果 无 法 识别 ， 则 系统 采用 UTC 时 区 。 
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例如 , 设置 北京 时 间 可 以 使 用 的 时 区 包括 PRC (中 华人 民 共和 国 ) 、Asia/Chongqing (重庆 ) 、Asia/Shanghai 
(上 海 ) 和 Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 区 名 称 是 等 效 的 。 


图 设计 过 程 

新 建 index.php 文件 ， 当 单 击 “ 地 区 时 间 ” 按 钮 时 ， 首 先 为 当前 PHP 服务 时 间 设 置 时 区 ， 并 通过 switchO 语 
名 根据 地 址 栏 传递 参数 的 不 同 ， 通 过 date0 函 数 获 取 不 同 国家 和 地 区 的 时 间 ， 其 代码 如 下 : 

<2php 


if($_POST[sub){ /通过 POST 方式 传 参 
date_default_timezone_set("Asia/ShangHai"); /设置 时 区 
switch($_POST[select){ 1/ 条件 语句 

case "中 国 "; /如 果 是 中 国 
echo date("H:i:s"); /输出 时 间 
[ /结束 语句 
case "英国 "; // 如 果 是 英国 
echo (date("H")-8).":".date("i:s"); /输出 时 间 
break: /| 结束 语句 
case "日 本 "; /如 果 是 日 本 
echo(date("H")+1).":".date("i:s"); /输出 时 间 
break; /| 结束 语句 
case "开罗 "; /如 果 是 开罗 
echo(date("H")-6).":".date("i:s"); /输出 时 间 
break; /| 结束 语句 
case " 划 斯 科 "; /如 果 是 莫斯科 
echo(date("H")-5).":".date("i:s"); /输出 时 间 
break; /| 结束 语句 
} 
1 
> 
秘笈 心 法 


心 法 领悟 141: 知识 扩展 。 
本 实例 只 是 简单 地 向 用 户 介绍 时 区 及 不 同 地 区 相差 的 小 时 数 ， 真 正 的 开发 中 ， 不 能 对 时 间 单 纯 地 进行 算术 
运算 ， 需 要 使 用 关键 技术 中 提供 的 方法 对 PHP 的 时 区 进行 设置 。 


| 
超 味 指 孝 再 记 记 商 


实例 142 


力 实例 说 明 
将 日 期 转换 为 时 间 戳 是 将 时 间 进 行 数学 运算 的 重要 手段 。 本 实例 通过 timeO) 函 数 实现 将 日 期 和 时 间 转 换 为 
时 间 惟 ， 运 行 结果 如 图 2.117 所 示 。 


当前 时 间 ，2010205=26j0516516 
转换 成 时 间 稚 为 ;N1277518576 


图 2.117 将 日 期 和 时 间 转 换 为 时 间 惟 


图 关键 技术 
获取 系统 UNIX 时 间 戳 的 方法 有 很 多 ， 使 用 time0 函 数 是 比较 常用 的 一 种 方法 ，time0 函 数 的 语法 如 下 : 
inttime ( void ): 
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该 函数 没有 参数 ， 返 回 值 为 UNIX 时 间 惟 的 整数 值 。 
图 设计 过 程 


创建 index.php 文件 。 首 先 ， 设 置 PHP 的 时 区 为 中 国 上 海 。 然后， 利用 time0O 函 数 获 取 当 前 的 时 间 戳 ， 并 通 
过 echo 语句 输出 时 间 惟 ， 其 代码 如 下 : 


<?php 
date_default_timezone set("Asia/ShangHai"): /设置 时 区 
echo "当前 时 间 : ".date('Y-m-d H:i:s”); /取得 当前 时 间 
echo "<br> 转 换 成 时 间 截 为 : "time0O: /转换 为 时 间 截 
> 

图 秘笈 心 法 


心 法 领悟 142: 知识 扩展 。 

将 当前 日 期 和 时 间 转 换 为 时 间 戳 的 方法 有 很 多 ， 下 面 通 过 strtotime0 函 数 实现 本 例 功能 ， 代 码 如 下 : 
ee timezone set("Asia/ShangHai"); /设置 时 区 

echo "当前 时 间 : "date(Y-md HEi:s); /设置 当前 日 期 和 时 间 

echo “转换 时 间 蕉 为 ，"strtotime("now"); // 转 换 时 间 截 

> 


实 上 日 高 级 | 
ee eee tne ess 


实例 说 明 
在 PHP 程序 设计 中 ， 日 期 和 时 间 是 具有 一 定格 式 的 ， 例 如 ， 今 天 是 一 年 的 第 多 少 天 等 。 本 实例 应 用 date0 
函数 通过 传 入 参数 不 同 实现 日 期 和 时 间 的 格式 化 ， 运 行 结果 如 图 2.118 所 示 。 
EF 10 点 21 分 28 秒 Al 
| 今天 是 一 周 的 第 6 天 , 是 一 年 的 第 176 天 
图 2.118 日 期 和 时 间 的 格式 化 


图 关键 技术 
本 实例 通过 date0 函 数 实现 日 期 和 时 间 的 格式 化 ， 详 细 说 明 请 参见 实例 035。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 设 置 PHP 的 时 区 为 中 国 上 海 。 然 后 ， 利 用 向 date0 函 数 中 传递 的 参数 不 同 实现 
Es 并 输出 格式 化 后 的 信息 ， 其 代码 如 下 : 


date | timezone set("Asia/ShangHai"); 1/ 设 置 时 区 
echo "当前 时 间 : "date(Y 年 月 d 日 互 点 i 分 s 秒 AY)."<br>"; /格式 化 日 期 和 时 间 
"本 月 有 ".date(t)." 天 .<br> 今 天 是 一 周 的 第 ".date(w)." 天 .是 一 年 的 第 "date(z)." 天 ": 
gg 将 该 文件 存储 于 \MR\02\143\ 文 件 夹 下 ， 命 名 为 index.php。 结果 如 图 2.118 所 示 。 
图 秘笈 心 法 


心 法 领悟 143: 知识 扩展 。 
date0 函 数 还 有 很 多 其 他 的 参数 ， 熟 悉 这 些 参数 的 使 用 可 以 在 使 用 格式 化 时 间 、 日 期 上 事半功倍 。 具 体 参 数 


EL 
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说 明 ， 请 参见 实例 035。 


趣味 指数 : 二 坪 穴 页 


图 实例 说 明 


在 PHP 语言 中 ， 要 完成 对 两 个 时 间 大 小 的 比较 ， 必 须 先 将 时 间 转 换 为 时 间 戳 ， 可 以 通过 strtotime0 函 数 完 
成 。 本 实例 就 应 用 strtotime0 函 数 对 两 个 固定 的 时 间 进 行 比较 ， 其 运行 结果 如 图 2.119 所 示 。 
日 期 多 
2010 年 6 月 26 日 比 2010 年 6 月 27 日 小 


图 2.119 比较 时 间 的 大 小 


图 关键 技术 


PHP 中 应 用 strtotimeO 函 数 将 任何 英文 文本 的 日 期 解析 为 UNIX 时 间 戳 ， 其 值 为 相对 于 now 参数 给 出 的 时 
间 ， 如 果 没 有 提供 此 参数 则 用 系统 当前 时 间 ， 此 时 与 实例 142 中 的 time0 函 数 相 同 。strtotime0 函 数 的 语法 如 下 : 

int strtotime ( string time [, int now] ); 

该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ， 如 果 参 数 time 的 格式 是 相 
对 时 间 ， 其 对 应 的 时 间 就 是 参数 now 来 提供 的 ， 当 没有 提供 参数 now 时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 
失败 ， 则 返回 false。 在 PHP 5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 编 写 <form> 表 单 并 设置 当前 时 区 为 中 国 上 海 ， 当 单 击 “ 日 期 比较 ”按钮 
时 ， 运 用 strtotimeO 函 数 获取 两 个 不 同时 间 点 的 时 间 戳 ， 并 进行 求 差 运算 。 最 后 ， 输 出 相关 提示 ， 其 代码 如 下 : 
<?php 


echo "<form action=" method='post>"; /输出 表单 
echo "<input type='submit name='sub' value=' 日 期 比较 >"; 
echo "</form>"; 
date_default_timezone_set("Asia/ShangHai"); /设置 时 区 
这 $_ POST[sub]){ /通过 POST 传 参 
Stime=date("Y 年 m 月 d 日 "); /取得 当前 日 期 
Stime_1 = timeO: /取得 当前 时 间 截 
Stime 2 = strtotime("27 June 2010"); /取得 固定 日 期 的 时 间 截 
if($time 2< $time 1){f /时 间 截 比较 
echo $time." 比 2010 年 6 月 27 日 大 "; 
Jelse{ 
echo $time." 比 2010 年 6 月 27 日 小 "; 
} 


四 
> 
(2) 将 该 文件 存储 于 \MR\02\144\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.119 所 示 。 
图 秘笈 心 法 


心 法 领悟 144: 使 用 strtotimeO 函 数 的 相关 说 明 。 

strtotime0 函 数 预期 接受 一 个 包含 美国 英语 日 期 格式 的 字符 串 ， 并 尝试 将 其 解析 为 UNIX 时 间 惟 〈 自 
January 1 1970 00:00:00 GMT 起 的 秒 数 ) ， 其 值 相对 于 now 参数 给 出 的 时 间 ， 如 果 没 有 提供 此 参数 则 用 系统 
当前 时 间 。 
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实例 145 st 六 太太 二 | 
例 说 明 ea 
计算 考试 时 间 程序 是 单纯 地 将 两 个 时 间 点 的 时 间 戳 做 算术 运算 。 本 实例 通过 您 用 时 5 和 答题 
time0 函 数 实现 考试 时 间 的 计算 ， 运 行 结果 如 图 2.120 所 示 。 图 2.120 计算 考试 时 间 


图 关键 技术 

本 实例 的 关键 点 是 timeO 函 数 的 灵活 运用 。 当 单 击 “ 开 始 答题 ”按钮 时 ， 将 time0 函 数 获 取 的 时 间 戳 存储 到 
SESSION 变量 中 ， 当 单 击 “ 答 题 完 毕 ”按钮 时 ， 再 次 通过 time0 函 数 获取 系统 的 当前 时 间 戳 。 当 前 时 间 戳 减 去 
开始 定义 的 时 间 截 ， 就 是 考试 所 用 时 间 。 
图 设计 过 程 

(1) 创 建 PHP 脚本 文件 。 首先 , 编写 <form> 表 单 并 设置 两 个 提交 按钮 , 当 每 个 按钮 被 单 击 后 , 利用 SESSION 
en 并 进行 求 差 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 


人 /输出 表单 
Ee ey we submit name='sub' value= 开始 答题 >&nbsp:<input type='submit name= 'sub_lvalue =' 答 题 完 毕 >"; 


ee 0 /通过 POST 方式 传 参 
Stime = timeO; /取得 当前 时 间 截 
$_SESSION['time’] = $time; /将 时 间 稚 保存 在 SESSION 中 
echo "<script>alert( 单 击 确定 开始 答题 ):</script>": /输出 提示 
} 
if($_POST[sub_1D{ /通过 POST 方式 传 参 
iftisset($_SESSION['time]){ 1/ 判断 SESSION 是 否 存 在 
echo "您 用 时 ".(time0-$_SESSION['time)." 秒 答题 "; /输出 结果 
session_destroy(); 1/ 销 明 session 
Jelse{ /否则 输出 提示 


echo "<script>alert( 您 还 没有 答题 无 法 结束 ， 请 先 答题 ! ):location href='index.php'</script>"; 
} 


} 
> 
(2) 将 该 文件 存储 于 \MR\02\145\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.120 所 示 。 
以 答 心 法 
心 法 领悟 145: 知识 扩展 。 
本 实例 运用 SESSION 机 制 保存 考试 的 开始 时 间 ， 然 后 完成 考试 时 间 的 计算 。 有 关 SESSION 机 制 的 详细 讲 
解 请 参考 本 书 第 5 章 的 内 容 。 


高 级 ] 
趣味 指数 : bobotol | 


图 实例 说 明 
倒计时 功能 的 实现 同样 也 是 将 时 间 戳 做 算术 运算 。 本 实例 应 用 strtotime0 函 数 实现 倒计时 程序 , 运行 结果 如 
图 2.121 所 示 。 
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当前 时 间 ，2010 年 06 月 26 日 1 点 25 从 50 和 
距 2011 年 元 日 还 有 189 天 


图 2.121 倒计时 
图 关键 技术 
本 实例 的 关键 点 是 strtotime0 函 数 的 灵活 运用 ， 详 细 说 明 参 见 实例 144。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 设 置 当前 时 区 为 中 国 上 海 。 首先， 利用 timeO) 函 数 取得 当前 时 刻 的 时 间 戳 并 保存 
在 变量 中 。 然 后 ， 利 用 strtotime0 函 数 取得 2011 年 1 月 1 日 的 时 间 惟 并 保存 在 变量 中 ， 将 两 个 时 间 惟 进行 求 差 
省 果 转 换 成 天 数 后 输出 ， 其 代码 如 下 : 


| default_timezone_set("Asia/ShangHai"); /设置 时 区 

echo "当前 时 间 : ".date('Y 年 m 月 d 日 HH 点 i 分 s 秒 )."<br>"; /输出 当前 日 期 

Stime = timeO; /取得 当前 时 间 截 

Stime r= strtotime("1 January 2011"); /取得 指定 日 期 的 时 间 截 


echo " 距 2011 年 元 旦 还 有 <b style='color:red;>".ceil((($time_r - $time)/(3600*24)))."</b> 天 "; /输出 
2 将 该 文件 存储 于 \MR\02\146\ 文 件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.121 所 示 。 
图 秘笈 心 法 
心 法 领悟 146: 时 间 比 较 的 原理 。 


通过 上 面 几 个 实例 用 户 应 该 明白 ， 其 实 所 有 的 时 间 比 较 归根 结 底 都 是 时 间 戳 的 比较 ， 所 以 掌握 时 间 稚 是 十 
分 重要 的 。 


实例 147 


国 实例 说 明 

闵 钟 是 人 们 生活 中 经 常 使 用 的 一 个 小 工具 ， 它 会 在 指定 时 间 叫 你 起 床 。 在 Web 程序 中 ， 也 可 以 应 用 这 个 原 
理 开发 一 个 “网 页 曾 钟 ”， 提 示 用 户 在 指定 的 时 间或 者 时 间 段 内 要 做 什么 工作 。 本 实例 通过 mktime0 函 数 实现 
网 页 闸 钟 程序 ， 运 行 结果 如 图 2.122 所 示 。 


Fo10 年 lo6 | 月 26 日 
14 办 15 分 00 种 


图 2.122 网 页 闹钟 


图 关键 技术 


PHP 中 , 应 用 mktime0) 函 数 将 一 个 时 间 转 换 成 UNIX 的 时 间 戳 值 。mktime0 函 数 根据 给 出 的 参数 返回 UNIX 
时 间 惟 。 时 间 戳 是 一 个 长 整数 ， 包 含 从 UNIX 纪元 到 给 定时 间 的 秒 数 。mktime0 函 数 的 语法 如 下 : 


intmktime ( [int hour [, int minute [, int second [, int month [, int day [. int year [. int is_dst]]]II] ): 


174 


mktime0 函 数 的 参数 说 明 如 表 2.8 所 示 。 
表 2.8 mktime() 函 数 的 参数 说 明 


参 数 说 了 明 

hour 小 时 数 

minute 分 钟 数 

second 秒 数 〔 一 分 钟 之 内 ) 

month 月 份 数 

day 天 数 

year 年 份 数 ， 可 以 是 2 位 或 4 位 数字 ，0-69 对 应 于 2000-2069，70-100 对 应 于 1970-2000。 

is dst 参数 is_dst 在 夏令 时 可 以 被 设 为 1， 如果 不是 则 设 为 0， 如果 不 确定 是 否 为 夏令 时 ， 则 设 为 -1 默认 值 ) 


图 设计 过 程 
(1) 创建 index.php 文件 。 首 先 ， 定 义 PHP 时 区 为 中 国 上 海 。 然 后 ， 编 写 <form> 表 单 ， 通 过 mktimeO 函 数 
实现 获取 当前 的 时 间 戳 ， 其 代码 如 下 : 


<?php 
echo "<table border='1' bordercolor=#FF0000' cellspacing='0' align='center><tr><td>"; /输出 表格 
echo "<h2 style='color:#0033FF> 闹 钟 程序 <h2>"; /输出 标题 
date_default_timezone_set("Asia/ShangHai"); /设置 时 区 
echo "<h6 style='color:red> 今 天 是 ".date("Y-m-d Hi:s")."</h6>"; /输出 当前 时 间 
echo "<form action=" method= post>": /输出 表单 
echo "<input type='text name=textl' size=2> 年 <input type='text name='text2' size='2> 月 "; 
echo "<input type='text name='text3' size=2'> 日 <br><input type='text name='text4' size=2> 时 "; 
echo "<input type='text name='text5' size=2> 分 <input type='text name='text6' size=2> 秒 <br>"; 
echo "<input type='submit’ name='sub' value= 定 时 >"; 
echo “</form>"; 
$a=$ POST[text1]: // 取 得 文本 框 内 容 
$b=$_POST[text2]; // 取 得 文本 框 内 容 
$c=$ POST[text3]: // 取 得 文本 框 内 容 
$d=$_POST[text4]: // 取 得 文本 框 内 容 
$e=$_POST[textS]; // 取 得 文本 框 内 容 
$f=$_POST[text6]: 1/ 取得 文本 框 内 容 
Stime = date(mktime($d, $e, $f, $b, $c, $a)); // 获 取 时 间 蕉 
$_SESSION['time’] = $time: /保存 在 SESSION 中 
这 $_POST[sub]){ /通过 POST 传 参 
echo"<script>window.location.href='in.php';</script>"; // 跳 转 
} 
echo "</td></tr></table>"; 
Ww 
(2) 创建 in.php 文件 ， 其 代码 如 下 : 
<?php 
date_default_timezone_set("Asia/ShangHai"): /设置 时 区 
Stime_1 = time0: /取得 当前 时 间 截 
这 $_SESSION[time]< $time_1){ 1/ 判断 条 件 
echo "<script>alert( 时 间 一 去 不 复 返 ):location href='index.php'</script>"; /| 输出 提示 
jelsef{ 
这 $_SESSIONTtime] 一 $time_D){ 1/ 判断 条 件 
echo "<script>alert( 今 天 是 XXX 生日 ):</script>"; /输出 提示 
jelsef /输出 提示 
echo "距离 XXX 的 生日 还 有 ".ceil((($_SESSION['time']-$time_1)/(3600*24)))." 天 ": 
} 
> 
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图 秘笈 心 法 


心 法 领悟 147: 不 同 版 本 的 操作 平台 对 UNIX 时 间 惟 的 支持 。 

PHP 为 UNIX 时 间 戳 的 处 理 提 供 各 种 函数 。 到 目前 的 PHP 版 本 为 止 ， 由 于 任何 已 知 Windows 版 本 以 及 一 
些 其 他 系统 均 不 支持 负 的 时 间 戳 ， 因 此 在 Windows 中 无 法 表示 1970 年 1 月 1 日 之 前 的 时 间 。 因 为 目前 UNIX 
时 间 惟 是 以 32 位 二 进 制 表示 的 ， 其 范围 为 (-2 147 483 648 ~ +2 147 483 647) ， 因 此 ， 目 前 UNIX 时 间 戳 可 表 
示 的 最 大 时 间 为 2038 年 1 月 19 日 3 点 14 分 7 秒 ， 该 时 刻 时 间 惟 为 2 147 483 647， 对 于 该 时 刻 之 后 的 时 间 ， 需 
要 扩展 表示 UNIX 时 间 戳 的 二 进 制 位 数 。 


图 实例 说 明 


在 百度 中 ， 当 执行 一 个 查询 操作 时 ， 获 取 到 查询 结果 后 ， 页 面 中 就 会 出 现 一 行文 字 ， 提 示 根 据 关键 字 搜 索 
到 多 少 个 结果 , 以 及 搜索 所 用 的 时 间 。 这 个 时 间 就 是 程序 在 执行 该 搜索 时 所 用 的 时 间 , 那么 它 是 如 何 实现 的 呢 ? 
下 面 就 模仿 它 来 做 一 个 计算 程序 运行 时 间 的 小 程序 ， 其 运行 结果 如 图 2.123 所 示 。 


中 高 2010 年 占 海 地 完 坦 歇 坛 天 过 还 有 18 和 天山 
倒计时 程序 的 运行 时 间 为 0 000308036804199 种 
图 2.123 计算 程序 运行 时 间 


图 关键 技术 


本 实例 的 关键 点 是 strtotimeO 函 数 的 使 用 ， 其 原理 是 : 首先 ， 在 执行 查询 操作 之 前 定义 一 个 时 间 ， 将 其 精确 
到 微 秒 ， 然 后 执行 查询 操作 ， 接 着 ， 在 查询 功能 执行 完毕 后 ， 再 次 获取 一 个 时 间 ， 同 样 精确 到 微 秒 ， 应 用 后 获 
取 的 时 间 减 去 最 初 获 取 的 时 间 ， 就 是 本 次 查询 所 用 的 时 间 。 
力 设计 过 程 

创建 index.php 文件 。 首 先 定义 ranm_time0 方 法 ， 获 取 系 统 当前 的 时 间 戳 。 然 后 调用 ran_time0 方 法 ， 获 取 当 


前 时 间 惟 ， 接 着 运行 程序 。 最 后 ， 再 次 调用 run_time0 函 数 ， 获 取 系 统 当前 时 间 ， 并 且 输 出 差 值 ， 获 取 程序 的 运 
行 时 间 ， 其 代码 如 下 : 


<?php 

人 # 声明 run_time 函数 

通过 microtime0 获 取 当 前 时 间 的 微 秒 数 和 时 间 截 

应 用 explode0 函 数 将 microtime0 函 数 返 回 的 字符 串 进行 分 隔 ， 返 回 一 个 数组 
包括 两 个 元 素 ， 一 个 元 素 是 当前 时 间 的 微 秒 数 ， 另 一 个 是 当前 时 间 的 时 间 截 
应 用 list0 函 数 将 explode0 函 数 返 回 的 数组 值 赋 给 指定 的 变量 

最 后 ， 获 取 两 个 变量 值 的 和 

机 

fanction run_timeO{ 


list($msec, $sec) = explode(" ". microtimeO): /使 用 explode0 函 数 返 回 两 个 变量 
Teturn ((float)$msec + (float)$sec): /返回 两 个 变量 的 和 
} 
Sstart time 一 run time0: /第 一 次 运行 man_time0 函 数 
让 运行 PHP 代码 段 *#/ 
Stimel = strtotime(date( "Y-m-d")): /1/ 当 前 的 系统 时 间 
$time2 = strtotime("2010-10-1"); /上 海 世界 博览 会 的 开幕 时 间 
S$sub2 = ceil(($time2 - $time1) / 86400): (60 秒 *60 分 *24 小 时 ) 秒 /天 


echo "距离 2010 年 上 海 世界 博览 会 开幕 还 有 <font color=red>$sub2 </font> 天 !!1"; 
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a 
S$end time = run time0: // 再 次 运行 ron_time0 函 数 
> 


<!-- 输出 差 值 ， 获 取 程序 的 运行 时 间 --> 
倒计时 程序 的 运行 时 间 为 <font color=blue> <?php echo ($end_time - $start_time); ?> </font> 秒 
> 


图 秘笈 心 法 


心 法 领悟 148: 在 PHP 中 应 用 日 期 、 时 间 函 数 时 的 注意 事项 。 

回 ”在 配置 PHP 时 , 进行 正确 的 时 区 设置 , 这 样 就 不 会 在 输出 时 间 时 出 现 输出 结果 与 当地 时 间 不 符 的 问题 。 

回 ”在 正确 地 配置 了 PHP 的 时 区 之 后 ， 就 是 使 用 日 期 、 时 间 函 数 获 取 日 期 、 时 间或 者 对 应 的 时 间 戳 ， 那 么 
必须 明确 一 个 日 期 、 时 间 在 不 同 的 操作 系统 中 的 有 效 范 围 ， 避 免 出 现 获 取 超 出 范围 的 日 期 、 时 间 数 据 
的 现象 。 

回 ”有 效 的 时 间 戳 范围 是 格林 威 治 时 间 1901 年 12 月 13 日 20:45:54~2038 年 1 月 19 日 03:14:07( 此 范围 符 

合 32 位 有 符号 整数 的 最 小 值 和 最 大 值 ) 。 

在 Linux 系统 中 此 范围 限制 为 从 1901 年 12 月 13 日 -2038 年 1 月 19 日 。 

在 Windows 系统 中 此 范围 限制 为 从 1970 年 1 月 1 日 -2038 年 1 月 19 日 。 

在 通过 日 期 、 时 间 函 数 获 取 日 期 、 时 间或 者 时 间 稚 时， 如 果 没有 指定 时 间 戳 ， 那 么 获取 的 是 本 地 时 间 。 


图 图 回 
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第 3 章 Web 页 面 交互 


3.1 获取 表单 元 素 的 值 


获取 表单 元 素 提交 的 值 是 表单 应 用 中 最 基本 的 操作 方法 , 通过 获取 表单 元 素 提交 的 值 可 以 实现 很 多 的 功能 ， 
例如 ， 添 加 用 户 注册 信息 、 提 交 用 户 登 录 信 息 、 添 加 学 生 详细 信息 等 。 下 面 通过 具体 实例 来 介绍 获取 表单 元 素 
提交 的 值 在 PHP 中 的 应 用 。 


运 味 指数 : 二 二 刘 宙 | 


图 实例 说 明 


论坛 是 许多 网 站 不 可 或 缺 的 模块 之 一 ， 它 为 人 们 相互 之 间 进 行 各 种 沟通 和 交流 提供 一 个 空间 。 设 计 论坛 模 
块 的 第 一 个 步骤 就 是 设计 论坛 登录 界面 ， 让 用 户 根据 自己 注册 的 用 户 名 和 密码 登录 论坛 。 在 本 例 中 笔者 设计 了 
一 个 简单 的 论坛 登录 界面 ， 效 果 如 图 3.1 所 示 。 


图 31 二 录 界面 
图 关键 技术 


在 设计 论坛 登录 界面 时 ， 主 要 采用 表格 标签 进行 界面 布局 ， 设 计 一 个 3 行 2 列 的 表格 ， 如 图 3.2 所 示 。 


图 3.2 利用 表格 标签 布局 


这 样 , 一 个 论坛 登录 界面 的 轮廓 就 形成 了 。 接 下 来 还 需要 为 表格 设置 背景 图 像 , 利用 表格 标签 的 background 
属性 即 可 ， 代 码 如 下 : 

<table width="392px" height="249px" align="center"><tr><td background="pic/tablebkjpg"> 
图 设计 过 程 

(1) 利用 Dreamweaver 开发 工具 创建 一 个 动态 PHP 页 ， 将 其 保存 为 “index.php”。 

(2) 添加 一 个 表单 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 调整 表格 各 行 的 高 度 和 列 的 宽度 。 

(3) 设置 表格 的 align 属性 为 “center”， 使 得 表格 在 表单 中 始终 居中 显示 。 

(4) 向 表格 单元 格 中 输入 用 户 名 称 和 密码 信息 ， 并 添加 文本 字段 和 按钮 。 

(5) 设置 “密码 ”文本 字段 的 类 型 (type) 属性 为 “password”， 使 其 以 掩 码 的 形式 隐藏 真实 密码 。 

(6) 实例 主要 代码 如 下 : 
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<form action="" 
<table align—"center"> 
<tr><td> 用 户 名 </td><td><input type="text" name="te" size="20" /></td></tr> 
<t><td> 密 : 码 <ftd><td><input type="password" name="tex" size="22" /></td></tr> 


<tr><td align="left"><input "type—"submit" name—"sub" value="&nbsp:&nbsp:&nbsp:S&nbsp:&nbsp:&nbsp:&nbsp:" /></td> 
es <td align="left"><input class="three" genbsp;&enbsp; genbsp; enbsp;" 
le> 
</form> 
图 秘笈 心 法 


心 法 领悟 149: 密码 框 与 文本 字段 宽度 不 一 致 的 解决 方案 。 

许多 初学 人 员 都 会 遇 到 这 种 情况 ， 在 设计 时 密码 框 的 宽度 与 文本 字段 宽度 相同 ， 但 是 在 浏览 器 中 显示 则 不 
相同 。 解 决 方法 是 在 密码 框 和 文本 字段 中 指定 统一 的 CSS 样式 , 即 设置 class 属性 。 在 PHP 页 面 中 添加 一 个 CSS 
样式 : 


这 样 ， 问 题 就 解决 了 。 


实例 150 


力 实例 说 明 


许多 大 型 网 站 为 了 吸引 用 户 ， 会 分 配 一 些 空间 供用 户 使 用 。 例 如 ， 大 家 经 常 使 用 的 电子 邮箱 、QQ 个 人 空 
间 等 。 为 了 能 够 让 用 户 在 个 人 空间 中 放置 自己 的 内 容 ， 网 站 都 会 提供 文件 、 图 片 等 信息 的 上 传 功能 。 例如 在 QQ 
个 人 空间 中 ， 用 户 可 以 上 传 自己 的 照片 ， 供 好 友 欣 赏 。 本 实例 利用 文件 域 实现 图 片 的 上 传 功 能 ， 效 果 如 图 3.3 
所 示 。 


朱 术 下放 


不 断 升 灼 的 楼 心 开 发 商 源 库 ， 为 您 开发 提供 遇 系 统 、 最 全 画 、 最 权 感 的 开发 撤 


糖 和 应 用 文章 ， 人 焰 技 术 章 不 着 、 技 ; 
四 不 全 面 、 技 术 无 到 用 等 开发 难 匡 和 困扰 。 


图 3.3 可 以 上 传 图 片 的 表单 


力 关键 技术 


在 本 例 中 ， 实 现 照 片上 传 的 主要 方式 是 利用 文件 域 让 用 户 加载 本 地 文件 ， 然 后 应 用 PHP 函数 
move Uploaded file0 实 现 文件 的 上 传 ， 效 果 如 图 3.4 所 示 。 


[一 辣 
'® 


3.4 文本 域 加 载 本 地 文件 
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move_uploaded_file0 函 数 可 将 上 传 的 文件 移动 到 新 位 置 ， 其 语法 如 下 : 
bool move_uploaded file ( string filename, string destination ): 

参数 说 明 : 

string filename: 指定 的 文件 是 合法 的 上 传 文件 。 

string destination: 定义 上 传 文件 的 名 称 。 


图 设计 过 程 
(1) 创建 动态 PHP 文件 ， 命 名 为 index.php。 


(2) 添加 一 个 表单 ， 将 type 属性 设置 为 fle， 代 码 如 下 : 
<form action="" method="post" enctype="multipart/form-data"> 
<input type="file" name="upfile" size="20" /> 
<input class="two"type="submit" name="sub" value="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" 亡 
</form> 


(3) 利用 <table> 标 签 ， 编 写 网 页 框架 。 
(4) 利用 编码 实现 上 传 功能 ， 核 心 代码 如 下 : 


<?php 
ifS_POST[sub]){ / 单 击 “ 上 传 ”按钮 
if($_FILES["upfile][name] — "){ / 漳 断 上 传 文件 名 称 是 否 为 空 
echo "<script>alert(' 上 传 内 容 为 室 ):</script>": 
jelsef 
S$info =$_FILES[upfile]; /将 上 传 文件 信息 保存 在 数组 中 
ifSinfo['size] > 0 &&c Sinfo[size] < 1024 * 8000){ /1/ 判 断 上 传 文件 的 大 小 
$dir = "upfiles/'; /定义 变量 
Sname = $info[name']; // 设 定 文件 名 称 
Srand = rand(0,10000000); 
Sname = $rand.date(YmdHis).Sname: 
Spath = upfiles/.$name; 
if(!is_dir($din){ 1/ 判断 文件 夹 是 否 存在 ， 如 果 不 存在 则 创建 一 个 文件 夹 
mkdir($dir); 
} 
Smove = move_uploaded_file($info['tmp_name"],Spath); 。 ”// 将 上 传 文件 移动 到 指定 位 置 
if(S$move — tme){ 
echo "<script>alert( 上 传 文件 成 功 );</script>"; 
} 
jelsef 
echo "<script>alert( 上 传 文件 过 大 );</script>"; 
} 
} 
} 
?> 
图 秘笈 心 法 


心 法 领悟 150: 解决 上 传 文件 重 名 问题 。 

如 果 用 户 建 立 个 人 网 站 ， 人 允许 他 人 上 传 文件 到 服务 器 中 ,但 是 每 一 个 浏览 网 站 的 用 户 并 不 知道 服务 器 中 是 
和 否 存在 与 即将 上 传 的 文件 重 名 的 文件 。 大 家 都 知道 ， 在 Windows 下 ， 同 一 个 文件 夹 中 ， 不 允许 两 个 同名 文件 的 
存在 ， 这 就 使 得 用 户 上 传 的 文件 名 称 必 须 是 独一无二 的 。 笔 者 为 上 传 文件 的 名 称 设 置 了 如 下 代码 : 

Sname = $info['name']; 7/ 设 定 文件 名 称 

Srand = rand(0,10000000): 

$name = Srand.date(YmdHis).Sname: 

$path = ‘upfiles/.$name; 


在 一 般 情况 下 ， 是 可 以 避免 上 传 文件 重 名 的 现象 的 。 
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ea 


高 级 
趣味 指数 ， 斌 寅 请 寅 : 


图 实例 说 明 
POST 方法 是 提交 表单 元 素 的 方法 之 一 ， 是 程序 员 提交 表单 的 主要 途径 。 运 行 本 实例 如 图 3.5 所 示 。 


图 3.5 通过 POST 方法 提交 表单 元 素 


图 关键 技术 


本 实例 实现 通过 POST 方法 提交 表单 元 素 ， 主 要 是 通过 定义 <form> 表 单 的 “method” 属 性 实现 ， 定 义 方法 
如 以 下 代码 所 示 : 
<form action="" method="post"> 
图 设计 过 程 
(1) 编写 脚本 文件 index.php。 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 文件 。 
(2) 编写 表单 ， 将 提交 方法 定义 为 post， 代 码 如 下 : 
<form action="" method="post"> /提交 方法 为 post 
<br> 
用 户 名 : <input class="one" type="text" name="te" size="20" /> 
<br> 
密 &nbsp:&nbsp: 码 ;<input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp:&nbsp:" 广 


<input class="three" type="reset" name="res" Value="&nbsp:&nbsp:" /> 
</form> 


图 秘笈 心 法 

心 法 领悟 151， 为 什么 POST 方法 是 程序 员 处 理 表单 程序 的 首选 ? 

POST 方法 与 GET 方法 不 同 ， 虽 然 都 是 采用 地 址 栏 传递 参数 的 方式 ， 但 是 通过 POST 方式 传递 的 参数 ， 在 
地 址 栏 中 是 不 可 见 ， 这 样 就 大 大 降低 了 网 站 或 者 程序 的 外 来 因素 的 威胁 。 
高 级 | 
E 


实例 
实例 152 起 味 指 玫 ， 窗 宣 二 请 


图 实例 说 明 
实例 151 介绍 了 如 何 通过 POST 方法 提交 表单 元 素 ， 本 实例 讲解 如 何 通过 POST 方法 获取 表单 元 素 。 运 行 
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本 实例 如 图 3.6 所 示 。 


REW，，，，，，，| 
二 055550 | 
【 生 豆 】 


| wm | ms | 


图 3.6 通过 $_POST 获取 表单 元 素 


图 关键 技术 

本 实例 实现 通过 $_ POST 方法 获取 表单 元 素 , 主要 是 利用 预定 义 变量 $ POST, 该 变量 是 一 个 自动 全 局 变量 ， 
即 它 在 所 有 的 PHP 脚本 中 都 有 效 。 

本 实例 通过 单 击 按钮 实现 访问 文本 框 信息 的 代码 如 下 : 

<tr> 


<td width="100px" align="center"><?php echo $ POST[te]:?></td> 
<td width="100px" align="center"><?php echo $ POST[pwdl:?></td> 
<t> 


图 设计 过 程 


(1) 编写 脚本 文件 mdex.php。 通 过 <table> 标 签 编 写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表单 ， 代 码 如 下 : 


<form action="" method="post"> 
<br> 
用 户 名 : <input class="one" type="text" name="te" size="20" /> 


a <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp:; " /> 
<input class="three" type="reset" name="res" value="&nbsp:" /> 
</form> 
(2) 当 单 击 “ 确 定 ”按钮 时 ,程序 首先 判断 文本 框 和 密码 框 信息 是 否 为 空 ， 当 不 为 空 时 ， 输 出 通过 $_POST 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
一 2pl 


hp 
这 $_POST[sub]){ /人 单 击 按钮 
if($_POST[te] — "||$_POST[pwd] — ""){ // 判 断 文本 框 和 密码 框 是 否 为 空 
echo "<script>alert( 文 本 框 不 能 为 空 );</script>"; 
Jelse{ 
?> 
<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"> 
<tr> 


<td align="center"> 用 户 名 </td> 
<td align="center"> 密 码 </td> 
</t> 
<t> 
<td width="100px" align="center"><?php echo $_ POST[te]:?></td> 
<td width="100px" align="center"><?php echo $ POSTfpwdl:?></td> 
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图 秘笈 心 法 

心 法 领悟 152， 超级 全 局 变量 9_ POST。 

虽然 $ POST 是 一 个 全 局 变量 ， 但 是 在 访问 的 时 候 不 需要 使 用 关键 字 global。 
高 级 


实例 153 趣味 指数 : | 


图 实例 说 明 


GET 方法 是 提交 表单 元 素 的 另 一 种 方法 ， 这 种 方法 虽然 不 是 程序 员 提 交 表 单 的 首选 ， 但 是 在 日 常 的 程序 开 
发 过 程 中 也 是 很 实用 的 。 运 行 本 实例 如 图 3.7 所 示 。 


图 3.7 通过 GET 方法 提交 表单 元 素 


图 关键 技术 

本 实例 实现 通过 GET 方法 提交 表单 元 素 ， 主 要 是 通过 定义 <form> 表 单 的 “method” 属 性 来 实现 ， 定 义 方法 
如 以 下 代码 所 示 : 

<form action="" method="get"> 
图 设计 过 程 

(1) 编写 脚本 文件 ndex.php， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 文件 。 


(2) 编写 表单 ， 将 提交 方法 定义 为 get， RE, 

<form action="" method="get"> /提交 方法 为 get 
<br> 
用 户 名 : <input class="one" type="text" name="te" size="20" /> 
<br> 
密 &nbsp:&nbsp: 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp: " /> 
<input class="three" type="reset" name="res" value="&nbsp: "> 

</form> 


力 秘笈 心 法 


心 法 领悟 153: GET 方法 与 POST 方法 的 本 质 区 别 。 
当 用 户 提交 表单 时 ， 观 察 GET 方法 和 POST 方法 在 地 址 栏 的 区 别 。POST 方法 不 会 有 任何 变化 , 而 GET 方 
法 将 在 地 址 栏 内 显示 如 图 3.8 所 示 的 内 容 。 


圈 Mttp://1ocahost/MR/03/0058006/in php?te=arspvi=arsoftasuk- 


3.8 ”GET 方法 提交 地 址 栏 变 化 


梧 
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虽然 传递 内 容 经 过 一 些 加 密 处 理 ， 但 是 也 是 近乎 明文 地 将 内 容 显 


实例 154 和 
图 实例 说 明 


通过 上 面 实例 的 学 习 ， 相 信用 户 已 经 掌握 了 什么 是 GET 方法 、 如 何在 表单 中 使 用 GET 方法 ， 下 面 将 通过 
$_GET 方法 向 用 户 演示 如 何 获 取 表单 元 素 ， 如 图 3.9 所 示 。 


图 3.9 通过 $_GET 方法 获取 表单 元 素 


图 关键 技术 

本 实例 通过 $_GET 方法 获取 表单 元 素 ， 主 要 应 用 预定 义 变量 $ GET， 本 变量 是 一 个 自动 全 局 变量 ， 即 它 在 
所 有 的 PHP 脚本 中 都 有 效 。 

本 实例 通过 单 击 “确定 ， 应 用 $_GET 方法 获取 文本 框 提交 的 数据 ， 其 代码 如 下 : 


width="100px" align="center"><?php echo $_GET[te]:?></td> 
<td width="100px" align="center"><?php echo $ GET[pwd]:?></td> 
</tr> 


图 设计 过 程 
(1) 编写 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表单 ， 代 码 如 下 : 
<form action="in.php" method="get"> 
用 户 名 : <input class="one" type="text" name="te" size="20" /> 
<br 
密 &nbsp:&nbsp: 码 :<input class="one” type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp:" /> 
<input class="three" type="reset" name="res" value="&nbsp:" /> 
</form> 
(2) 当 单 击 “确定 ”按钮 时 ， 程 序 首先 判断 文本 框 和 密码 框 信息 是 否 为 室 ， 当 不 为 空 时 ， 输 出 通过 $_GET 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
<?php 


这 $_GET[sub]){ / 单 击 按钮 
这 $ I "1$_GET[pwd] —""){ /1/ 判 断 文本 框 内 容 
echo "<script>alert( 文 本 框 不 能 为 空 ):</script>"; 
jelsef 


> 

<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"><tr><td align="center"> 用 户 名 </td><td align="center"> 密 码 </td></tr> 
<tr><td width="100px" align="center"><?php echo $ GET[tel:?></td><td width="100px" align="center"><?php echo 
$_GET[pwd]:?></td></tr></table> 

<?php 
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了 
} 


> 


国 秘笈 心 法 

心 法 领悟 154: 超级 全 局 变量 $_GET。 

与 全 局 变量 $_POST 一 样 ，$_GET 方法 页 不 需要 使 用 关键 字 global 来 访问 。 通 过 $_GET 方法 还 可 以 获取 到 
超 链接 传递 的 参数 值 。 


3.2 文本 框 组 件 的 应 用 


文本 框 组 件 是 用 来 输入 任何 类 型 的 单行 文本 、 数 字 或 字母 数据 的 文本 域 。 在 进行 程序 设计 过 程 中 ， 经 常 使 
用 文本 框 组 件 来 获取 用 户 输入 的 信息 。 下 面 通 过 具体 实例 来 说 明文 本 框 组 件 在 PHP 中 的 应 用 。 


高 级 | 


趣味 指数 : 禽 窒 侠 侠 | 


图 实例 说 明 


在 开发 网 站 的 过 程 中 ， 一 般 涉及 到 用 户 注 册 的 网 站 模块 都 有 一 个 用 户 注册 的 服务 条 款 ， 个 别 的 服务 条 款 以 
整个 网 页 进行 显示 ， 但 是 有 的 网 站 因 服 务 条 款 篇 幅 过 长 ， 不 适合 使 用 这 种 方式 ， 最 好 的 解决 方法 是 以 文本 域 
的 形式 来 显示 ， 既 可 节省 页 面 ， 又 美观 大 方 。 运 行 本 实例 ， 在 文本 域 中 显示 用 户 注册 的 服务 条 款 ， 运 行 效果 如 
图 3.10 所 示 。 


请 仔细 圈 污 以 下 休 款 


不 全 下 布吉 反 国 家 全 下 法规 朋 内 ” 忆 
得 发 布 违反 社会 道德 的 内 容 。 


rms]| 


3.10 ”以 文本 域 形 式 显示 数据 


图 关键 技术 
本 实例 主要 应 用 表单 中 的 文本 域 显示 信息 ， 主 要 就 是 设置 文本 域 的 初始 值 ， 代 码 如 下 : 
<textarea name="test" cols="45" rows="8" id="test"><?php echo $myrow[text]:?></textarea> 
参数 说 明 : 
name: 文本 域 的 名 称 。 
cols: 文本 域 的 字符 宽度 。 
rows: 文本 域 显示 的 行 数 。 


设计 过 程 
(1) 编写 脚本 文件 ， 编 写 文本 域 代码 ， 并 通过 PHP 变量 传递 初始 值 ， 代 码 如 下 
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<?php 

$str = "用 户 不 得 发 布 违 反 国家 行政 法 规 的 内 容 。 /定义 变量 
不 得 发 布 违反 社会 道德 的 内 容 。": 

> 


<form action="" method="post"> 
<div align="center"> 
<textarea name="txt" id="one" cols="30" rows="6"><?php echo $str:?></textarea> 1/ 传递 初始 值 
<br> 
<br 
<input type= "submit" name="agreen" id="agreen" value= "接受 (8)” disabled="disabled"/> 
&nbsp:&nbsp:&nbspi&nbsp; 
<input type="submit" name="disagreen" id="disagreen" value=" 不 接 受 "/> 
</div> 
</form> 


也 笈 心 法 


心 法 领悟 155: 文本 域 标签 的 初始 值 。 
文本 框 标签 和 其 他 一 些 标签 ， 设 置 初始 值 的 方法 是 将 初始 内 容 写 在 “value” 属 性 之 中 ， 而 文本 域 标签 的 初 
始 值 内 容 是 写 在 文本 域 的 开始 和 结束 标签 之 间 的 。 


9 高 级 
让 od 


力 实例 说 明 

在 网 站 的 论坛 或 意见 箱 中 ， 留 言 的 内 容 通常 都 是 在 文本 域 中 输入 的 ， 而 文本 域 不 具有 限制 用 户 输入 最 多 字 
符 数 的 功能 ， 因 此 必须 由 开发 人 员 编 写 代码 进行 控制 。 运行 本 实例 ， 在 “意见 内 容 ”文本 框 中 只 能 输入 1000 个 
字 节 ， 即 1000 个 英文 字母 或 500 个 中 文 汉 字 , 用 户 在 文本 框 中 每 输入 一 个 字符 ， 下 面 的 字 节 位 置 都 将 自动 计算 
已 输入 字 节 数 和 剩余 字 节 数 ， 运 行 结果 如 图 3.11 所 示 。 


到 
I” Br | 
| | 
3.11 限制 文本 域 输入 的 字符 个 数 


图 关键 技术 
要 实现 限制 多 行文 本 域 输入 的 字符 个 数 ， 关 键 是 应 用 onKeyDown 事件 和 onKeyUp 事件 ， 调 用 自 定义 的 
JavaScript 函数 StatByte0， 来 限制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 。 


四 设计 过 程 


(1) 创建 一 个 企业 内 部 意见 箱 的 文本 框 ， 代 码 如 下 : 

<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions"></textarea> 

(2) 添加 显示 字 节 数 的 文本 框 ， 包 括 最 大 字 节 数 、 已 用 字 节 和 剩余 字 节 ， 注 意 此 时 应 该 将 这 3 个 文本 框 设 
置 为 停 用 状态 ， 不 允许 用 户 修改 ， 代 码 如 下 : 


最 大 字 节 数 : 
<input name="maxs" type="text" disabled class—"noborder" id-"maxs” value="1000" size="4"> 
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已 用 字 节 : 

<input name="used" type="text" disabled class="noborder" id="used"” value="0" size="4"> 
剩余 字 节 : 

<input name="remain" type="text" disabled class="noborder" id-remain" value="1000" size="4"> 


(3) 编写 自 定义 的 JavaScript 函数 StatByte0， 用 于 判断 用 户 输入 的 字符 数 是 否 大 于 允许 输入 的 字符 数 ， 并 


function StatByte(Message.maxs.Used.Remain){f // 字 节 统 计 
var ByteCount = 0; 
var StrValue = Message.value; 
var StrLength = Message.value.length: 
var maxsValue =maxs.value; 


if(LastCount != StrLength) { / 在 此 判断 ， 减 少 循环 次 数 
for (i=0,i<StrLength:iH+){ 

ByteCount = (StrValue.charCodeAt(i)<=256) ? ByteCount + 1 : ByteCount + 2; 

if (ByteCount>maxsValue) { 


Message.value = StrValue.substring(0,); 
alert(" 留 言 内 容 最 多 不 能 超过 " +maxsValue+ ”个 字 节 ! n 注意 ， 一 个 汉字 为 两 字 节 。"); 
ByteCount = maxsValue: 
break; 
} 
Used.value = ByteCount; 
Remain.value = maxsValue - ByteCount; 
LastCount = StrLength; 
} 
} 
(4) 修改 “意见 内 容 ” 文 本 域 的 代码 ， 在 onKeyDown 事件 和 onKeyUp 事件 中 调用 自 定义 的 JavaScript 函 
数 StatByte0， 限 制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 ， 代 码 如 下 : 


<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions' 


onKeyDown="StatByte(this.form.suggestions,this.form.maxs,this.form.used,this.form.remain);" 
onKeyUp="StatByte(this.form.suggestions,this.form.maxs.this.form.used.this.form.remain):"> 
</textarea>> 


图 秘笈 心 法 


心 法 领悟 156: 字 节 数 的 计算 。 
在 计算 字 节 数 时 ， 需 要 判断 输入 的 字符 是 汉字 还 是 英文 字母 或 数字 ， 因 为 一 个 汉字 占 两 个 字 节 。 


实例 157 


力 实例 说 明 

在 网 页 中 ， 有 些 文本 框 中 的 信息 是 不 允许 浏览 者 进行 修改 的 ， 即 用 户 只 有 浏览 的 权限 ， 而 没有 修改 的 权限 。 
此 功能 可 以 通过 设置 文本 框 的 只 读 属性 来 实现 。 运 行 本 实例 ， 在 页 面 中 修改 库存 数量 时 ， 将 弹出 “此 文本 框 为 
只 读 属性 ， 库 存 数 量 不 能 修改 ! ! ”的 提示 框 ， 运 行 结果 如 图 3.12 所 示 。 
图 关键 技术 

本 实例 的 关键 是 文本 框 中 readonly 属性 的 运用 , 通过 它 可 设置 文本 框 的 只 读 属 性 , 然后 通过 onfocus 事件 调 
用 JavaScript 脚本 ， 当 用 户 单 击 已 经 设置 为 只 读 属性 的 文本 框 时 ， 弹 出 一 个 提示 对 话 框 。 

使 用 readonly 属性 实现 只 读 的 代码 如 下 : 


<input id="0" class="o" type="text" readonly value=0100521041'/> 
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现 甩 7 六 有 


100521041 


| 


图 3.12 设置 文本 框 的 只 读 属性 
图 设计 过 程 


新 建 index.php 文件 。 编 写 表 格 ， 在 表格 中 插入 <form> 标 签 ， 编 写 文 本 框 ， 设 置 文 本 框 的 属性 为 readonly， 
代码 如 下 : 


<form action="" method="post"> 

商品 编号 ，<input id="0" class="0" type="text" readonly value=- 0100521041/><br> 

商品 名 称 ，<input id="o"type="text" value=" 酸 牛奶 " onfocus="this.value=" /><br> 

库存 数量 <input id="o" class="n"type="text" disabled="disabled" value="100 件 " /><br> 
管理 员工 :<input id="o"type="text" value="001" /> 

</form> 


图 秘笈 心 法 


心 法 领悟 157: 使 用 readonly 的 小 技巧 。 
在 使 用 readonly 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


力 实例 说 明 
在 物流 管理 系统 中 ， 经 常 需要 计算 出 库 商品 的 金额 或 入 库 商 品 的 金额 ， 若 以 手工 计算 ， 比 较 麻烦 而 且 容易 
出 错 ， 如 果 在 程序 中 实现 自动 计算 金额 功能 ， 则 可 以 减少 许多 不 必要 的 麻烦 。 运 行 本 实例 ， 如 图 3.13 所 示 。 


三 


商品 编 | 和 二 
商品 单价 : | 


库存 数量 : [35 
£ 全 上 额 关 计 : 350 


图 3.13 ”自动 计算 金额 
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图 关键 技术 

本 实例 主要 通过 触发 表单 控件 的 Blur 事件 ， 即 表单 控件 失去 焦点 时 ， 实 现 自 动 计算 金额 。 实 现 此 功能 的 
JavaScript 代码 如 下 : 

SC.0")blur(fanctionO{ // 当 商品 单价 文本 框 失 去 焦点 


Price 
S$(".e").val(amount); 

D; 
图 设计 过 程 

(1) 编写 脚本 文件 并 命名 为 index.php。 引 入 CSS 样式 表 文 件 ， 导 入 JavaScript 脚本 。 编写 表 单 ， 当 商品 单 
价 失去 焦点 时 自动 计算 金额 ， 核 心 代码 如 下 : 

<form action="" method="post" name="form1"> 

商品 编号 ，<input id="o" type="text" readonly value= 酸 牛奶 /><br> 

商品 单价 ，<input id="o" type="text"class="0" value="0.0"/><br> 

库存 数量 : <input id="o" class="n"type="text" value="35" readonly /><br> 

金额 总 计 : <input id="0" class="e"type="text" value="0.0" /> 

</form> 


秘笈 心 法 


心 法 领悟 158: 关于 Blur 事件 。 
用 于 当 Blur 事 件 ( 即 失去 焦点 事件 ) 发 生 时 执行 JavaScript 代码 。 适 用 对 象 包括 Button、Checkbox、FileUpload、 
Layer、 Password、Radio、Reset、Select、Submit、Text、Textarea 和 Window。 


Eee 
实 高 
so | ee 


图 实例 说 明 


在 实例 157 中 ， 笔 者 已 经 向 用 户 介绍 了 文本 框 只 读 属 性 的 相关 知识 。 接 下 来 向 用 户 介绍 一 种 与 只 读 属 性 类 
似 的 属性 ， 即 设置 文本 框 默认 值 。 运 行 本 实例 ， 如 图 3.14 所 示 ， 设 置 文本 框 的 默认 颜色 为 灰色 ， 当 在 用 户 名 中 
输入 信息 时 动态 改变 文本 框 默 认 值 信息 。 

从 河 让 必 = 下 汉 


3.14 为 文本 框 设置 默认 值 


图 关键 技术 


本 实例 的 关键 是 通过 disabled 属性 设置 文本 框 的 默认 值 ， 然 后 通过 相关 事件 ， 动 态 改变 默认 值 文本 框 的 值 。 
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使 用 disabled 属性 设置 默认 值 的 代码 如 下 : 
<input id="0" class="0" type="text" disabled value="0100521041'/> 
图 设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 样式 表 文件 ， 编 写 表 单 ， 代 码 如 下 : 


table width="350" border="0" class="p"> 
<tr> 
<td width="100"> 用 户 名 : </td> 
<td align="left"><input class="m" id="name"type="text" /></td> 
<t> 
<u> 
<td> 职 &nbsp:&nbsp: 位 : </td> 
<td align="left"><input class="m"type="text" id="type” disabled value=" 自 动 选取 "/></td> 
<t> 
</table> 


(2 定义 JavaScript 脚本 方法 ， 动 态 改变 文本 框 的 默认 值 ， 代 码 如 下 : 


SC#type") val(" 程 序 员 "); 
入 
图 秘笈 心 法 
心 法 领悟 159: 关于 设置 文本 框 的 默认 值 。 
ki 可。 只 读 属 性 ， 在 效果 上 是 相同 的 。 
(2) 在 使 用 disabled 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


ee 
高 级 | 
起 呆 要 才 ; 商 商 宙 | 


力 实例 说 明 


<form> 表 单 的 文本 框 在 默认 情况 下 不 够 美观 ， 使 用 默认 的 文本 框 样式 将 影响 网 站 的 视觉 效果 。 运行 本 实例 ， 
如 图 3.15 所 示 ， 利 用 CSS 代码 和 简单 的 JavaScript 代码 ， 使 文本 框 变 得 生动 、 有 特色 。 


方案 由 心 


提供 完整 方案 的 计 思 路 、 实 现 过 程 与 实施 步 邓 。 帮 助 编程 者 提高 方案 开发 的 


图 3.15 设置 文本 框 样式 
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图 关键 技术 


本 实例 首先 为 文本 框 定义 CSS 样式 ， 然 后 通过 设置 鼠标 事件 调用 CSS 样式 ， 动 态 改变 文本 框 的 边框 颜色 。 
使 用 CSS 样式 的 代码 如 下 : 

bender lps #FFO000 solit 
background-color-#FFCCFF; 
} 
使 用 JavaScript 定义 鼠标 事件 ， 代 码 如 下 : 
S$("#n").mouseover(functionO{ 

S$("#n").css({border:"1px #0099FF solid",background:"white"}); 

$("#n").mouseout(functionO{ 

S$("#n").css( {border:"1px red solid",background:"#FFCCFF"}); 


外 
$("#na").mouseover(functionO{ 
S$("#na").css({border:"1px #0099FF solid",background:"white"}); 
$("#na").mouseout(function(){ 
S("#na").css( {border:"1px red solid",background:"#FFCCFF"}); 
D; 
入 


图 设计 过 程 


(1) 新 建 index.php 文件 ， 建 立 网 页 架构 ， 编 写 <form> 表 单 ， 其 关键 代码 如 下 : 
<table width="350" border="0" class="p"> 
<t> 
<td width="100"> 用 户 名 :</td> 
<td align="left"><input type="text" class="mouse" id="n"/></td> 
</tr> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : </td> 
<td align="left"><input type="text" class="mouse" id="na" /></td> 
<ltr> 
</table> 


(2) 引入 CSS 样式 和 JavaScript 脚本 ， 核 心 代码 如 关键 技术 中 所 示 。 


力 秘笈 心 法 


心 法 领悟 160: 如 何 引 入 CSS 样式 。 
定义 CSS 样式 表 后 需要 引入 到 相关 脚本 文件 中 才能 起 到 作用 。 一 般 是 在 <meta> 标 签 下 ， 利 用 <link> 标 签 引 
入 。 以 本 实例 为 例 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/inc.css"/> 


力 实例 说 明 
文本 域 本 身 有 自 带 的 滚动 条 ， 用 户 可 以 通过 滚动 条 浏览 文本 域 中 的 所 有 内 容 ， 但 是 在 初始 情况 下 ， 用 


户 可 以 根据 需要 设置 文本 域 的 列 宽 ， 也 就 是 确定 文本 域 在 初始 情况 下 显示 多 少 内 容 ， 运 行 本 实例 如 图 3.16 
所 示 。 


192 


第 3 章 Web 页 面 交 互 


并 让 了 ; 志 杨 再 也 提 不 上 了 只 能 业者 站 噩 
= 内 疝 前 天 着 。 计 下 一 坛 。 密 坊 副 天 


各 各 


图 3.16 文本 域 的 滚动 条 


图 关键 技术 
本 实例 的 关键 点 是 利用 JavaScript 代码 ， 动 态 改变 文本 框 的 rows 属性 。JavaScript 代码 如 下 : 


‘textarea").attr("rows","1"); 


图 设计 过 过 程 
(1) 新 建 index.php 文件 , 通过 <table> 标 签 建立 网 页 框架 , 输入 文本 域 代码 ， 引 入 CSS 样式 表 和 JavaScript 
脚本 ， 代 码 如 下 : 


<table width="600" height="600" border="0" align="center" background="pic/bgjpg"> 


<input sn id='up' value='&nbsp; 必 


on 
(2) 编写 JavaScript 脚本 文件 ， 输 入 如 关键 技术 所 示 代 码 。 
图 秘笈 心 法 


心 法 领悟 161: 编写 JavaScript 代码 的 注意 事项 。 
编写 JavaScript 代码 时 ， 要 注意 JavaScript 代码 是 区 分 函数 的 大 小 写 的 。 


3.3 ”下拉 列 表 的 应 用 


下 拉 列 表 是 一 种 最 节省 空间 的 数据 显示 方式 ， 正 常 状态 下 只 能 看 到 一 个 选项 ， 单 击 控制 按钮 后 ， 可 以 显示 
一 定数 量 的 选项 ， 如 果 超出 这 个 数量 ， 会 自动 显示 滚动 条 ， 浏 览 者 可 以 通过 拖 动 滚动 条 来 查看 各 选项 。 


实例 162 | 


We ee 


力 实例 说 明 
在 进行 网 站 开发 的 过 程 中 ， 经 常会 用 到 相互 关联 的 菜单 。 例 如 ， 省 、 市 、 县 3 级 联动 或 者 省 、 市 2 级 联动 
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菜单 。 在 本 实例 中 ， 将 讲解 如 何 实现 省 、 市 2 级 联动 菜单 ， 其 运行 效果 如 图 3.17 所 示 。 


图 3.17 省 、 市 级 联动 菜单 


图 关键 技术 


本 实例 通过 设置 change 事件 实现 联动 的 下 拉 列 表 ， 并 且 根 据 1 级 下 拉 列表 传递 的 不 同 参数 ， 显 示 不 同 的 2 
级 下 拉 列 表 人 信息。 实现 这 些 功能 的 JavaScript 代码 如 下 : 
S$("#select1").change( function|) { 
var id = $("#select1").val(); 
ifid— D{ 
S$.get(index.php', null, function(data){ 
$("span”").empty(); 
$("span").append("<select><option> 长 春 </opton><option> 松 原 </opton><option> 通 辽 </opton></select>"); 
jekef 
$.get(index.php', null, function(data){ 
S$("span").emptyO; 
SO'span").append("<select><option> 大 连 </opton><option> 旅 顺 </opton><option> 钱 鱼 圈 </opton></select> 
D; 
} 
D; 


图 设计 过 程 


(1) 创建 脚本 文件 , 引入 CSS 样式 表 和 JavaScript 脚本 。 编写 1 级 下 拉 列 表 , 设置 <option> 标 签 属性 “value” 
的 值 ， 代 码 如 下 : 
<select id="select1"> 
<option value="” selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 
</select> 


(2) 编写 JavaScript 代码 ， 当 选择 1 级 下 拉 列 项 时 ， 触 发 change 事件 ， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 162: JavaScript 脚本 语言 的 小 技巧 。 
如 果 在 JavaScript 脚本 中 出 现 长 语句 , 可 以 在 JavaScript 语句 的 最 后 加 上 字符 “\”, 使 一 条 长 语句 分 多 行 编写 。 


实例 163 高 级 i 


[a 食 谷 人 商 催 


国 实例 说 明 
实例 162 中 讲解 了 如 何 实现 2 级 联动 菜单 ， 下 面 将 向 用 户 讲解 如 何 实现 省 、 市 、 县 3 级 联动 菜单 。 运 行 本 
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实例 ， 如 图 3.18 所 示 。 


二 


图 3.18 省 、 市 、 县 级 联动 菜单 


图 关键 技术 


实现 省 、 市 、 县 3 级 联动 菜单 与 实现 2 级 联动 菜单 的 思路 大 致 相同 ， 只 不 过 需要 套用 多 层 的 计 ..else.… 语 名 
实现 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 命 名 为 ndex php。 创 建 form 表单 ， 编 写 下 拉 列 表 框 ， 定 义 2 级 联动 和 3 级 联动 的 下 
拉 列 表 选 项 ， 代 码 如 下 : 


<select id="select1"> 
<option value=" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 
</select> 
<span id='two'></span> 
<span id='three'></span> 
(2) 编写 JavaScript 脚本 文件 ， 当 触发 change 事件 时 ， 实 现 联动 效果 ， 代 码 如 下 : 
S$("#select1").change( function| { 
var id = $("#select1").val|; 
iflid = Df 
S.get(index.php' null, function(data) { 
S$("#two").emptyO; 
S$("#two").append("<select id='select2'><option> 请 选择 </opton><option value='1> 长 春 </opton><option value='2> 松 原 
</opton></select>"); 
S("#select2").change( function0 { 
Var page = $("#select2").valO; 
ifltpage — D{ 
S("#three").emptyO; 
$("#three").append("<select><option> 双 阳 </opton><option> 农 安 </opton></select>"); 
jelsef 
if(page — 2){ 
S$("#three").emptyO; 
$("#three").append("<select><option> 蓝 安 </opton><option> 大 安 </opton></select>"); 


} 
DD; 


D; 
jelsef 
S$.get(index.php' null function(data){ 
S("#two").emptyO; 
S$("#two").append("<select id-'select3><option value="1> 大 连 </opton><option value=2 人 > 旅顺 </opton></select>"): 
S('#select3").change( functionO { 
var page = $("#select3").val(): 
iflpage — D{ 
S("#three").emptyO; 
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S$("#three").append("<select><option> 西 岗 </opton><option> 沙 河口 </opton></select>"); 
jekef 
iflpage — 2){ 


S("#three").emptyO: 
S$("#three").append("<select><option> 金 州 </opton><option> 瓦 房 店 </opton></select>"); 


国 秘笈 心 法 


心 法 领悟 163: 打造 优秀 的 3 级 联动 菜单 。 
本 实例 意 在 讲述 实现 3 级 联动 菜单 的 原理 ， 在 实际 开发 中 是 不 建议 使 用 让 .…else..…. 语 句 的 ， 因 为 这 样 的 多 层 
嵌 套 方式 一 方面 使 程序 本 身 的 可 读 性 变 差 ， 而 且 还 有 可 能 不 利于 程序 员 编 程 。 


实例 164 


图 实例 说 明 


在 开发 网 站 程序 的 过 程 中 ， 多 数 网 站 都 设置 了 友情 链接 这 一 模块 ， 通 常情 况 下， 链接 的 网 站 以 图 标 、 网 站 
名 或 地 址 的 形式 显示 在 页 面 中 ， 浏 览 者 可 通过 单 击 超 链接 进入 所 要 访问 的 网 站 。 为 了 更 好 地 利用 页 面 ， 可 以 通 
过 下 拉 列 表 的 方法 来 创建 友情 链接 。 运 行 本 实例 ， 当 用 户 选择 下 拉 列 表 中 所 要 联机 的 网 站 后 (如 图 3.19 所 示 ) ， 
单 击 GO 按钮 可 以 立即 链接 到 指定 的 网 站 。 


， 应 有 尺 有 


多 种 基色 了 配 他 方案 、 著 百 御 职 色 Pf Ed 


[rm EA] 


根 方 鲁 | 


图 3.19 应 用 下 拉 列 表 选 择 要 联机 的 网 站 


本 实例 首先 将 文本 框 的 value 属性 值 定义 为 所 要 连接 的 人 P 地 址 ， 然 后 通过 设置 鼠标 的 单 击 事件 实现 链接 到 


alert( 请 选择 连接 内 容 ); 
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图 设计 过 程 
(1) 新 建 index.php 文件 ， 创 建 下 拉 列 表 框 ， 并 添加 下 拉 列 表 框 选 项 值 ， 代 码 如 下 : 


<selectid="sel"> 
<option value="" > 友情 链接 </option> 
<option value="http://www.126.com">126 邮箱 </option> 
<option value="http://www.163.com">163 i 
<option value="http://www.4399.com">4399 小 游戏 </option> 
‘</select> 
<input id="button" class="button' type="submit" value="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" 亡 


(2) 编写 JavaScript 脚本 文件 ， 当 单 击 GO 按钮 时 触发 事件 ， 完 成 页 面 的 跳 转 操作 。 
图 秘笈 心 法 


心 法 领悟 164: 使 用 CSS 样式 表 的 好 处 。 
利用 CSS 样式 可 以 大 量 减少 网 页 代码 ， 其 原理 就 是 在 网 页 中 自 定义 样式 表 的 选择 符 ， 在 网 页 中 大 量 引 用 这 
些 选 择 符 即 可 。 


实例 165 


国 实例 说 明 


通常 ， 网 页 中 应 用 的 下 拉 列 表 的 选项 值 是 固定 不 变 的 ， 这 样 就 存在 一 些 棘 病 ， 如 不 能 向 下 拉 列 表 中 添加 新 
的 选项 值 。 如 果 能 编写 可 以 输入 字符 的 下 拉 列 表 ， 就 方便 很 多 。 运 行 本 实例 ， 在 部 门 的 下 拉 列 表 框 中 有 “生产 
部 ”、“ 业 务 部 ”和 “技术 部 ”3 条 记录 ， 如 果 要 再 添加 一 个 “文化 部 ”， 直 接 在 下 拉 列 表 框 中 输入 “文化 部 ” 
即 可 ， 运 行 结 果 如 图 3.20 所 示 。 


， 应 有 尽 
多 种 新 色 配 全 方案 、 熙 百 秆 客 色 办 色 秆 文案: 数 于 个 按 鱼 种 表 案 村 ， 设 计 真 的 | 
很 方 更 ! 


图 3.20 可 输入 字符 的 下 拉 菜 单 


力 关键 技术 


本 实例 的 开发 思路 如 下 : 网 页 中 下 拉 列 表 的 选项 值 是 固定 的 ， 要 实现 在 下 拉 列 表 中 输入 文字 ， 首 先 要 捕获 
用 户 的 键盘 事件 ， 然 后 根据 键盘 输入 的 数据 动态 添加 下 拉 列 表 的 选项 ， 同 时 还 要 判断 用 户 按 下 的 是 “ 退 格 ” 键 
还 是 “空格 ” 键 ， 如 果 是 “ 退 格 ” 键 ， 则 需要 从 光标 指针 位 置 向 前 删除 一 个 字符 ， 如 果 是 “空格 ” 键 ， 则 需要 
在 光标 指针 位 置 添加 一 个 空格 字符 。 

另外 ， 本 实例 还 利用 onKeyPress 和 onKeyUp 事件 调用 JavaScript 自 定义 函数 press(opt) 和 up(opt)。 


PHP 开发 实战 1200 例 (第 I 卷 ) 
设计 过 程 


(1) 在 页 面 中 创建 部 门下 拉 列 表 ， 其 中 包括 “生产 部 ”、“ 业 务 部 ”和 “技术 部 ”3 个 选项 ， 代 码 如 下 : 
<form name="form1" method="post" action="index.php" onKeyPress="press(3)" onKeyUp="up(3)"> 
‘<select name="userclass" size="1" id="userclass"> 
<option value=" 生 产 部 " selected> 生 产 部 </option> 
<option value=" 业 务 部 "> 业务 部 </option> 
<option value=" 技 术 部 "> 技术 部 </option> 
‘</select> 
/form> 
(2) 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 press(opb， 用 于 在 下 拉 列 表 中 添加 新 的 选项 ， 并 将 
用 户 输入 的 信息 添加 到 下 拉 列 表 中 ， 设 置 该 选项 为 选中 项 。 
然后 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 up(opt)， 当 用 户 按 BackSpace 键 时 ， 将 已 经 写 到 下 
拉 列 表 中 的 文字 逐个 删除 ， 当 用 户 按 Space 键 时 ， 在 下 拉 列 表 中 添加 一 个 空格 字符 ， 代 码 如 下 : 
function press(opt){ 
/lopt 表示 现 有 可 选项 的 数目 
forml.userclass.options[optj=new Option(ok=(forml.userclass.options[opt)? 
forml .userclass.options[opt].innerText+String.fromCharCode(event.keyCode): 
String.fromCharCode(event.keyCode),ok) 
forml .userclass.selectedIndex=opt; 
} 
function up(opb{ 
Wopt 表示 现 有 可 选项 的 数目 
ifforml userclass.options[opt){ 
iflevent.keyCode—8){ 
Var str=form1.userclass.options[opt].innerText; 
var len=str.length: 
forml .userclass.options[opt] innerText=str.substring(0,len-1): 
if(form!l.userclass.options[opt].innerText—" ")userclass.remove(2); 
: 
iflevent.keyCode—32){ 
forml .userclass.options[opt].innerText+=" "; 
} 
} 
} 


图 秘笈 心 法 


心 法 领悟 165: 使 用 JavaScript 代码 删除 输入 文字 的 注意 事项 。 
在 删除 输入 选项 中 的 文字 时 ， 如 果 删 除 到 最 后 一 个 字符 ， 则 将 该 选项 一 同 删除 ， 同 时 改变 下 拉 列 表 的 选 
中 项 。 


实例 166 趣味 指教 ， 育 高 育 部 


力 实例 说 明 


在 注册 登录 模块 中 ， 下 拉 列 表 往 往 被 应 用 在 选择 用 户 性 别 上 ， 如 果 用 户 忘记 选择 此 下 拉 列 表 的 内 容 ， 就 很 
容易 把 注册 信息 弄 错 。 解 决 这 个 问题 的 方法 是 为 下 拉 列 表 设 置 默认 值 ， 如 图 3.21 所 示 ， 当 没有 对 下 拉 列 表 进 行 
操作 时 ， 将 弹出 提示 信息 。 
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图 3.21 设置 下 拉 列表 的 默认 值 


力 关键 技术 


本 实例 首先 为 下 拉 列 表 框 设置 默认 值 ， 然 后 通过 设置 按钮 的 单 击 事件 实现 当 用 户 单 击 提交 按钮 时 ， 判 断 下 
拉 列 表 框 的 内 容 是 否 被 选择 。 

使 用 selected 属性 实现 设置 默认 值 的 代码 如 下 : 

<option selected value="1"> 请 选择 性 别 </option> 


图 设计 过 程 


(1) 新 建 ndex.php 文件 ， 引 入 CSS 文件 和 JavaScript 脚本 ， 编 写 下 拉 列 表 ， 代 码 如 下 : 
<select> 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
‘</select> 
<input id="one" type="button" value="&nbsp;é&nbsp; Snbsp;&nbsp;&nbsp; Senbsp:é&nbsp:&nbsp;" /> 
(2) 编写 JavaScript 代码 ， 当 按钮 被 单 击 时 触发 事件 ， 其 代码 如 下 : 
S$(document) ready(functionO{ 
S$("#one").click(function|{ 
var value = $("select").valO; 
value — D){ 
alert(" 您 没有 选择 性 别 "); 
} 
D; 
DD: 


图 秘笈 心 法 


心 法 领悟 166: 关于 设置 下 拉 列 表 的 默认 值 。 
在 使 用 selected 时 ， 只 需 在 <option> 标 记 中 加 入 属性 名 称 即 可 ， 其 代码 如 下 : 


‘<option selected="selected"></option> 


高 级 
超 味 指 雪 : 再 再 让 计 


国 实例 说 明 
其 实 对 页 面 的 美化 处 理 ， 并 不 属于 程序 员 的 工作 范畴 ， 而 是 属于 前 台 美工 的 份 内 之 事 ， 但 是 像 这 种 美化 下 
拉 列 表 的 小 事情 ， 程 序 员 如 果 还 要 和 美工 去 协调 ， 未 免 有 点 浪费 时 间 ， 所 以 用 户 学 习 一 些 基本 的 页 面 美化 方法 
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还 是 很 有 必要 的 。 运 行 本 实例 ， 效 果 如 图 3.22 所 示 。 


3.22 ”设置 下 拉 列 表 的 样式 


图 关键 技术 
本 实例 运用 CSS 样式 表 改 变 下 拉 列 表 的 样式 ， 代 码 如 下 : 


select{ 

width: 100px:; 
font-family:" 楷 体 _GB2312"; 
font-size: 14px; 
Color:#FFFFFF:; 
background-color:#000000; 

} 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 ， 编 写 下 拉 列 表 ， 代 码 如 下 : 


<select> 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
</select> 


(2) 定义 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 
以 答 心 法 
心 法 领悟 167: 关于 设置 下 拉 列 表 的 样式 。 


支持 下 拉 列 表 的 CSS 样式 很 少 ， 所 以 想 设 置 更 多 的 样式 ， 相 对 来 说 会 很 麻烦 。 如 果 非 要 定义 一 个 漂亮 的 下 
拉 列 表 样 式 ， 最 好 利用 JavaScript 代码 自行 编写 。 


本 
高 级 | 


趣味 指数 : 规 商 催 窗 


国 实例 说 明 


实例 164 中 已 经 讲解 了 如 何 跳 转 到 链接 网 站 的 方法 ， 本 实例 与 实例 164 在 实现 思路 上 是 相同 的 ， 唯 一 不 同 
的 是 在 下 拉 列 表 里 通过 打开 新 窗口 实现 跳 转 。 运 行 本 实例 ， 如 图 3.23 所 示 。 
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方案 中 心 


要 供 完 坚 方 案 的 至 体 设计 电路、 实现 过 程 与 实施 步 枝 。 帮 助 编程 者 提高 方案 开发 的 | 


图 3.23 选择 链接 网 站 


图 关键 技术 


本 实例 的 方法 是 定义 JavaScript 脚本 的 change 事件 ， 通 过 JavaScript 的 window.open0 方 法 ， 实 现 新 页 面 的 
跳 转 ， 代 码 如 下 : 

$(document).ready(fonction0)f 

S$("#sel").change(functionO{ 

i window.open($("#sel").valO); 

DD; 


| | 设计 过 程 
(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 表 和 JavaScript 脚本 ， 编 写 下 拉 列 表 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/inc.css"/> 
‘<script type="text/javascript" sre="../js/iquery-1.3.2.js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
‘<selectid="sel" > 
<option> 友 情 链接 </option> 
<option value=http://www.126.com>126 邮箱 </option> 
<option value= http://www.163.com'>163 邮箱 </option> 
<option value=http://www.4399.com'>4399 小 游戏 </option> 
</select> 


(2) 编写 JavaScript 脚本 文件 ， 当 发 生 change 事件 时 ， 发 生 跳 转 。 
图 秘笈 心 法 
心 法 领悟 168: 关于 JavaScript。 


本 章 内 容 主 要 采用 JavaScript 语言 和 jQuery 框架 编写 , jQuery 框架 是 以 JavaScript 语言 编写 的 , 所 以 两 者 可 
以 混 编 。 


力 实例 说 明 


Tab 键 在 编写 Word 等 文档 时 是 经 常 被 用 到 的 。 在 网 页 的 文本 域 中 ， 按 Tab 键 是 进行 下 一 个 切换 项 的 指示 ， 
如 何在 文本 域 中 体现 Tab 键 呢 ? 本 实例 将 向 用 户 讲解 。 运 行 本 实例 ， 如 图 3.24 所 示 。 
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方案 由 六 


提供 完 鉴 方案 的 整体 设计 电路 、 实 现 过 程 与 实施 步 慑 。 帮 助 编程 者 提高 方案 开发 的 
实际 操作 上 能 - 


业 积累 经 验 ， 
公司 : 


字 化 出 版 得 
是 国内 软件 名 牌 企 
国内 IT 教育 知名 企业 | 。 到 


图 3.24 文本 域 中 体现 Tab 键 


力 关键 技术 


本 实例 主要 是 通过 JavaScript 代码 定义 onkeydown 事件 实现 的 ， 代 码 如 下 : 
function editTabOf{ 
Var code, sel tmp,T 
Var tabs="" 
event.returnValue = false 
Sel =event.srcElement.document.selection.createRange() 
r= event.srcElement.createTextRange() 
switch (event.keyCode){ 
case (8) 2 
if (!(sel.getClientRects().length > 1){ 
event.retumValue = true 
Tetum 
} 
code = sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRect(.left, sel.getClientRectsO[0].top) 
sel.setEndPoint("start ToStart", tmp) 
sel.text = sel.text.replace(/^\/gm, "") 
Code = code.replace(/^M\t/gm, "").replace(/\i\n/g, "\r") 
rfindText(code) 
rselectO 
break 
case(9) : 
if (sel.getClientRects().length > 1){ 
code = sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRectO left. sel.getClientRectsO[0].top) 
sel.setEndPoint("startToStart", tmp) 
sel.text = "\t"+sel.text.replace(/\r\n/g, Et) 
code = code.replace(/\r\n/g, "\n\t") 
r.findText(code) 
TselectO 
Yelsef 
sel.text = "\t" 
selselect0 
} 
break 


case (13) 
tmp = seLduplicateO) 
tmp moveToPoint(r.getBoundingClientRectO .left, sel.getClientRectsOfOl.top) 
tmp.setEndPoint("endToEnd", sel) 
for (var i=0; tmp.text.match(/^N\t]+/g) && i<tmp.text.match(/^M\t]+/g)[O].length: i++) tabs += "\t" 
sel.text = "\r\n"+tabs 
sel.selectO 
break 
default 
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eventretumValue = true 
break 


} 
} 


图 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 JavaScript 脚本 ， 编 写 文本 域 标签 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/inc.css"/> 
<textarea cols="30" name="text" rows="3" onkeydown="editTab()"></textarea> 
(2) 当 按 下 键盘 按键 时 触发 事件 ， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 169: JavaScript 脚本 的 引用 。 
本 实例 中 调用 JavaScript 中 的 editTab0 完 成 对 Tab 键 的 控制 ， 在 页 面 中 引用 JavaScript 文件 的 方法 是 应 用 
script 标签 ， 其 代码 如 下 : 


3.4 表单 元 素 的 动态 操作 


所 谓 动态 操作 表单 元 素 是 指 页 面 中 的 表单 元 素 并 不 是 固定 不 变 的 ， 而 是 在 程序 执行 时 由 系统 根据 实际 情况 
自动 生成 。 这 里 将 通过 实际 的 例子 来 介绍 如 何 动 态 生成 表单 元 素 。 
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力 实例 说 明 


在 开发 程序 的 过 程 中 ， 经 常 应 用 到 在 线 投票 模块 ， 其 使 用 非常 简单 ， 只 要 选中 一 个 单 选 按钮 或 者 多 个 复 选 
框 所 对 应 的 投票 主题 后 ， 单 击 “ 提 交 ” 按 钮 即 可 完成 投票 。 本 实例 将 介绍 投票 系统 的 操作 原理 ， 当 选中 一 个 投 
票 主题 之 后 , 就 会 弹出 相应 的 投票 选区 , 在 该 选区 中 可 以 添加 投票 ， 并 可 以 看 到 投票 的 结果 , 运行 结果 如 图 3.25 
所 示 。 


bbe 
和 如果 在 访 程 词典 中 没有 烹 需 要 的 录像 ， 请 及 时 反 铺 给 我 们 .我 们 全 力 安 振 专 寄 央 / 
te 


me 


3.25 在 线 统计 
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图 关键 技术 


本 实例 主要 是 通过 文件 操作 和 正则 表达 式 函 数 实现 在 线 统计 程序 。 其 中 文件 操作 的 核心 代码 如 下 : 
Sfile = file_get_contents(info.txt); 
ifSfile—™){ 
Sopenn = fopen("info.txt",'a): 
fwrite($openn,'a’); 
fclose($openn): 
小 
这 preg match("/$ip/",$file)){ 
echo "<script>alert( 同 一 个 人 P 地 址 ， 不 能 投票 两 次 );</script>"; 
it; 
jelsef 
if(!$open = fopen("info.txt",a)){ 
print "文件 不 存在 ， 请 创建 ": 


exit; 

jelsef 
fwrite($open, $ip); 
fclose($open); 

} 


} 
图 设计 过 程 

(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 文件 和 JavaScript 脚本 ， 编 写 单 选 按钮 ， 代 
人 码 如 下 : 


<form action="" method="post"> 
<t> 
<td class="three"><input id="id" name="check" checked type="radio" value="1" /> 上 网 </td> 
<td><img src="picllogol.JPG" /><font color=red size="-1">10 人 </font></td> 
<tr> 
<tr> 
<td class="three"><input id="id"name="check" type="radio" value="2" /> 去 娱乐 场所 </td> 
<td><img src="pic/logo2.JPG" /><font color='Tred'size="-1">15 人 </font></td> 


<td class="three"><input id="id"name="check" type="radio" value="3" /> 带 着 女友 和 逛街 </td> 
<td><img src="pic/logo3.JPG" /><font color=red'size="-1">20 人 </font></td> 


<td class="three"><input id="id"name="check" type="radio" value="4" /> 睡觉 </td> 
<td><img src="pic/logo4.JPG" /><font color='red'size="-1">5 人 </font></td> 
</tr> 
</form> 
(2) 当 单 击 “ 确 定 ” 按 钮 时 ， 首 先 获取 客户 端 人 P 地 址 ， 然 后 将 数据 写 入 到 文本 文件 中 ， 最 后 根据 提交 的 


值 通过 switchO 语 句 进行 判断 给 出 提示 信息 ， 代 码 如 下 : 


<?php 
if($ POST[sub){ 
Sip=$_SERVER[REMOTE_ADDR]: /取得 客户 端 卫 地址 
Sfile = file_get_contents(info.txt); // 将 文件 内 容 读 取 到 字符 串 
这 $file — ""){ /如 果 文 件 内 容 为 空 
Sopenn = fopen("info.txt",'a); /打开 info.txt 文 件 
fwrite($openn,'a’): /向 文件 中 写 入 一 个 字符 
fclose($openn): /1/ 关 闭 文件 
} 
if(preg_match("/$ip/".$file){ // 匹 配 字符 串 、 
echo "<script>alert( 同 一 个 人 P 地 址 ， 不 能 投票 两 次 ):</script>": 
exit; /退出 
jelsef 


这 tsopen = fopen("info:txt",a){ 
print "文件 不 存在 ， 请 创建" 
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Case "3"; 

echo "<script>alert( 您 选择 和 女友 逛街 );</script>”: 
Case "4"; 

echo "<script>alert( 您 选择 睡觉 );</script>"; 
case nl 

echo "<script>alert( 您 选择 上 网 );</script>"; 
break; 

} 


} 
> 


力 秘笈 心 法 


心 法 领悟 170: 关于 对 文件 的 操作 。 
文件 的 操作 ， 对 于 所 有 学 习 PHP 这 门 语言 的 人 来 说 ， 都 会 感到 头疼 ， 特 别 是 对 文件 的 高 级 操作 中 的 指针 的 
理解 ， 更 是 如 此 。 所 以 笔者 建议 ， 在 学 习 这 部 分 知识 时 ， 一 定 要 先 打 好 基础 ， 然 后 多 实践 、 多 思考 。 
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图 实例 说 明 


论坛 系统 中 的 会 员 有 不 同 的 级 别 ， 一 种 是 超级 会 员 ， 拥 有 对 论坛 的 管理 权限 ， 另 一 种 是 普通 会 员 ， 只 能 发 
布 和 回复 论坛 信息 。 因 此 在 论坛 的 权限 设置 模块 中 就 需要 应 用 单 选 按钮 对 超级 会 员 和 普通 会 员 设 置 不 同 的 权限 。 
在 本 实例 中 ， 选 中 “超级 会 员 ” 单 选 按 钮 时 ， 其 下 方 将 列 出 网 站 的 所 有 管理 模块 ， 管 理 员 可 以 为 超级 会 员 设置 
管理 权限 ， 运 行 结果 如 图 3.26 所 示 ; 选中 “普通 会 员 ” 单 选 按钮 ， 运 行 结果 如 图 3.27 所 示 。 


如 时 在 编程 调 眶 中 没有 他 需要 的 录像 ， 请 及 时 反馈 馆 我 们 ， 我 们 全 旋 安 排 专家 其) 如 果 在 闹 得 河 现 中 没有 灯 壳 要 的 录像， 请 及 时 反 铺 绽 我 们 ， 我 们 全 力 安排 专 朋 制 
开发 视频 录像 ， 并 及 时 升级 到 编 召 词 跨 录 像 宫 。 开发 视频 录 间 ， 和 并 及 时 升级 到 编程 词典 录像 中 。 


图 3.26 ”超级 会 员 设 置 图 3.27 普通 会 员 设 置 
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图 关键 技术 
选中 单 选 按钮 后 显示 其 他 表单 元 素 的 功能 ， 主 要 利用 JavaScript 设置 表格 的 display 样式 ， 来 实现 表格 的 显 
示 和 隐藏 。 通 过 设置 表格 的 ID 属性 ， 可 以 实现 对 表格 的 整体 控制 ， 如 设置 表格 的 style (样式) 属性 。 通 过 将 
表格 的 display 样式 设置 为 “none”， 可 以 控制 表格 的 隐藏 将 表格 的 display 样式 设置 为 “block”， 可 以 显示 
表格 。 
图 设计 过 程 
(1) 创建 脚本 文件 , 利用 <table> 标 签 编写 网 页 架构 , 引入 CSS 样式 表 和 JavaScript 脚本 , 编写 <form> 表 单 ， 


代码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" src="../is/iquery-1.3.2.js"></script> 
<script type="text/javascript" src="js/in js"></script> 
<table align="center"> 
<t> 
<td> 用 户 名 :</td> 
<td><input type="text"/></td> 
</> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : </td> 
<td><input type="text"/></td> 
</tr> 


<t> 
<td> 权 限 设置 :</td> 
<td><input id="va" type="radio" name="ch" value="1" checked/> 超 级 用 户 <input id="val" name="ch"type="radio" value="2" /> 普通 用 户 </td> 
</tr> 
<t> 
<td><table id="name1"><tr><td><input type="checkbox" /> 帖子 管理 </td></tr></table></td> 
<td><table id="name2"><tr><td><tr><td><input type="checkbox" /> 后 台 管 理 </td></tr></table></td> 


<td><table id="name3"><tr><td><tr><td><input type="checkbox" /> 数 库 管理 </td></tr></table></td> 
<td><table id="name4"><tr><td><tr><td><input type="checkbox" /> 公告 管理 </td></tr></table></td> 
</tr> 
</table> 


(2) 编写 JavaScript 脚本 文件 ， 将 <style> 属 性 动态 添加 到 复 选 框 的 表格 中 ， 控 制 表 格 的 隐藏 和 显示 ， 代 码 


如 下 : 

S$(document).ready(functionO{ 

S$("#va").click(functionO{ 
S("#namel").css("display"."block"): 
S$("#name2").css("display","block"): 
S$("#name3").css("display","block"): 
S$("#name4").css("display"."block"): 

入 

S$("#val").click(functionO{ 
$("#namel").css("display","none"); 
S$("#name2").css("display","none"): 
S$("#name3").css("display","none"): 

S$("#name4").css("display","none”): 

D; 


图 秘笈 心 法 


心 法 领悟 171: 添加 CSS 属性 。 
利用 jQuery 框架 可 以 很 容易 地 将 属性 和 值 动态 地 添加 到 指定 标签 中 ; 语法 格式 为 : 
S$("class/id").attr("key"."value”):; 
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实例 172 趣味 指数 : 会 神谷 请 | 


图 实例 说 明 
PHP 这 门 语言 是 一 种 服务 器 端的 编程 语言 ， 顾 名 思 义 ， 在 需要 时 与 服务 器 进行 交互 ， 并 且 处 理 信息 ， 但 是 


很 多 时 候 , 用 户 希 望 在 与 服务 器 交互 之 前 就 完成 一 些 操作 。 这 个 时 候 客户 端 脚本 语言 JavaScript 的 作用 就 体现 出 
来 了 。 运 行 本 实例 ， 通 过 JavaScript 代码 实现 不 提交 表单 获取 单 选 按钮 的 值 ， 如 图 3.28 所 示 。 


3.28 不 提交 表单 获取 单 选 按钮 的 值 


力 关键 技术 


本 实例 主要 是 通过 JavaScript 代码 定义 click 事件 ， 获 取 单 选 按钮 的 值 ， 并 且 将 单 选 按钮 的 值 通过 div 标签 
返回 到 页 面 中 ， 代 码 如 下 : 
S$(document) ready(functionO{ 
$(".n").mouseover(functionO{ 
$(".n").css({background:"#FFCCCC",border:"1px red solid"}); 
$(".n").mouseout(functionO{ 
S$(".n").css( {background:"white".border:"1px #00CCFF solid"}): 


了 
$(".o").mouseover(function0O{ 
$(".0").css( {background:"#FFCCCC",border:"1px red solid"}): 
$(".0").mouseout(function(){ 
$(".0").css( {background:"white",border:"1px #00CCFF solid"}): 


D; 

SC#e") click(functionO{ 
S$("#nam").css("display","block"); 
var value = $("#e").val|; 

S$("#name”).html(value):; 

SC"#ee").click(functionO{ 
S$("#nam").css("display","block"): 
var value = $("#ee") val(); 
S$("#name").html(value): 

条 

图 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 ， 创 建 用 户 登 录 的 form 表单 ， 设 置 文本 框 和 单 
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选 按钮 元 素 ， 并 且 设 置 div 标签 ， 定 义 标 签 的 ID 值 ， 核 心 代码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" src="../js/iquery-1.3.2.js"></script> 
<script type="text/javascript" src="js/in.is"></script> 
<table align="center"> 
<t> 
<td> 用 户 名 : </td> 
<td><input class="n" type="text" /></td> 
<lt> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <ltd> 
<td><input class="o" type="text" /></td> 
</tr> 


<t> 
<td><input id="e" name="ch"type="radio" value=" 保 存 密码 " 广 保存 密码 </td> 


<td><input id="ee" name="ch"type="radio" value=" 隐 身 登录 " /> 隐身 登录 </td> 
</tr> 


<t> 
<td id="nam"> 单 选 按钮 值 为 ，</td> 
<td><div id="name"></div></td> 
<l> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 引 入 jQuery 库 文件 jquery-1.3.2.js。 


图 秘笈 心 法 


心 法 领情 172: jQuery 中 的 click 事件 。 
di 语法 格式 如 下 : 
S$("class/id").click(functionO{... 


高 级 | 
趣味 指数 : 合 傅 请 亢 


图 实例 说 明 


复 选 框 应 用 在 用 户 注册 系统 中 ， 例 如 个 人 爱好 选择 等 。 本 实例 所 讲述 的 3 个 操作 :全 选 、 反 选 、 不 选 ， 只 
是 根据 实际 情况 ， 对 复 选 框 实现 的 快捷 操作 。 运 行 本 实例 ， 全 选 的 效果 如 图 3.29 所 示 。 


明日 科技 网 站 
Wp abood com 例 收 蕊 本 站 ” 固 设 为 首页 岛 联 系 我 们 
篇 程 司 奥 体 装 。。” 蝙 竹 司 奥 介绍 。 篇 民 司 身 在 线 服 务 会 加 总 理 退出 登录 


人 会 员 数据 管理 


欢迎 光临 明日 科技 网 站 
会 员 信息 管理 
所 欧阳 PHP 部 门 经 理 多 
古 下 方 JAVA 部 门 经 理 » 
历 夏 使 mc 部 门 公理 » 
历 南宫 有 部 门 肥 理 多 


技术 服务 热线 : 0431-64978981 84978982 
Copyright 回 mw singrisoft. com All Rights Reservedl 


图 3.29 实现 全 选 
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图 关键 技术 
复 选 框 的 全 选 、 反 选 和 不 选 主要 应 用 JavaScript 脚本 ， 通 过 自 定义 函数 完成 。 

(1) 在 通过 JavaScript 脚本 中 的 自 定义 函数 完成 复 选 框 的 全 选 、 反 选 和 不 选 功能 中 ， 应 用 的 第 1 个 方法 是 
getElementsByYTagName， 获 取 指定 标签 的 名 称 ， 返 回 值 为 一 个 包含 标签 信息 的 object。 

(2) 根据 getElementsByTagName 标签 返回 的 对 象 ， 判 断 标签 类 型 〈type) 的 值 是 否 是 checkbox。 

(3) 当 标签 类 型 type 的 值 为 checkbox 时 ， 为 标签 中 的 checked 赋值 。 当 checked 的 值 为 TRUE 时 ， 将 其 
赋值 为 FALSE; 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 

(4) 在 页 面 中 通过 script 标签 调用 js 文件 夹 中 的 文件 ， 应 用 onClick 事件 调用 自 定义 函数 ， 完 成 全 选 、 反 
选 和 不 选 功能 的 实现 。 


图 设计 过 程 


(1) 创建 js 文件 来 ， 编 写 regjs 脚本 文件 。 在 regjs 中 ， 编 写 自 定义 函数 ， 实 现 全 选 、 反 选 和 不 选 功能 。 


reg.js 文件 的 关键 代码 如 下 : 
fanction uncheckAll(forml ,status) { // 不 选 
var elements = form1.getElementsByTagName('input); /获取 input 标签 
for(var i=0; i<elements.length; iH+){ /根据 标签 的 长 度 执行 循环 
这 elements[i] type 一 ' checkbox) { /判断 对 象 中 元 素 的 类 型 
if(elements[i].checked—true) { 1/ 判断 当 checked 的 值 为 TRUE 时 
elements[i].checked=false; /| 将 checked 赋值 为 FALSE 
} 
} 
, 
function checkAll(form! ,status){ // 全 选 


var elements = forml.getElementsByTagName(input); 
for(var i=0; i<elements.length: 计 +){ 
if(elements[il.type — ‘checkbox’) { 


if(elements[i].checked—false){ 
elements[il.checked=true; 
} 
} 
} 
} 
function switchAll(forml,status) { /反选 


Var elements = forml .getElementsByTagName("input’); 
for(var i=0; i<elements.length: i++){ 
这 elementsfil.type — ‘checkbox){ 
iflelements[i].checked——true){ 
elements[i].checked=false; 
jelse if(elements[i].checked—false){ 
elements[i].checked=true; 
} 


} 
} 


(2) 创建 index.php 页 面 ， 输 出 会 员 信息 ， 并 添加 图 像 按钮 ， 通 过 onClick 事件 调用 JavaScript 自 定义 函数 


实现 全 选 、 反 选 、 不 选 和 删除 的 功能 ， 其 关键 代码 如 下 : 
<script language="javascript" sre="js/regjs"></script> 
<form method="post" name="form1" id="form1" action="index._ok.php"> 
<t> 


<td width="62" align="center"><input name="conn_id[]" type="checkbox" id="conn id[]" value="1" /></td> 
<td width="242"> 欧 阳 </td> 

<td width="243">PHP</td> 

<td width="485"> 部 门 经 理 </td> 

<td width="485">29</td> 
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</t> 


<tr> 

<td colspan=-"$" align="center"><!-- 通 过 onClick 事件 调用 自 定义 函数 ， 执 行 相应 的 操作 --> 

<img src="images/bg 19-20jpg" onclick="checkAll(form1.status)" width="62" height="25" /> 
<img sre="images/bg_14-14.jpg" onclick="switchAll(form1.status)” width="62" height="25" /> 
<img sre="images/bg 07-08.ipg" width="62" height="25" onclick="uncheckAll(forml.status)" /> 

<input type—"image" name="imageField" src="images/bg_14jpg" /> 

<htd> 

</t> 

</form> 


图 秘笈 心 法 


心 法 领悟 173: 复 选 框 的 全 选 、 反 选 和 不 选 的 实现 思路 。 

复 选 框 的 全 选 、 反 选 和 不 选 主 要 应 用 JavaScript 脚本 ， 通 过 JavaScript 脚本 中 的 自 定义 函数 ， 判 断 复 选 框 中 
checked 的 值 。 全 选 就 是 将 checked 赋值 为 TRUE， 不 选 则 是 将 checked 赋值 为 FALSE， 而 反选 则 是 当 checked 
的 值 为 TRUE 时 ， 将 其 赋值 为 FALSE: 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 


例 说明 


开发 在 线 论坛 系统 时 ， 在 回复 帖子 的 模块 中 ,要 记录 是 谁 回 复 了 哪 一 个 帖子 ， 即 要 把 这 个 回复 用 户 的 ID 同 
回复 帖子 的 内 容 一 起 保存 起 来 。 回 帖 的 内 容 是 从 文本 域 中 获取 的 ， 而 回帖 人 的 ID 则 是 通过 隐藏 域 进行 提交 的 ， 
不 需要 手动 填写 ， 如 图 3.30 所 示 。 


对 


聊 区 二 位 为 : 有 081 

Ht， 明日 科技 A 

hst%- 明 日 科技 是 一 家 为 名 的 钦 作 它 司 
3 = 


图 3.30 隐藏 域 提交 用 户 ID 


转 关键 技术 


本 实例 主要 应 用 表单 中 的 隐藏 域 来 实现 文件 值 的 提交 和 获取 。 
表单 中 隐藏 域 的 语法 格式 如 下 : 

<input type= "hidden" name= "ID" value=""> 

参数 说 明 : 

type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 。 

name: 隐藏 域 的 名 称 ， 可 以 自己 定义 。 

value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 。 
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图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ,编写 表单 ， 代 码 
如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text/iavascript" src="js/in.is"></script> 
<table width="600px" height="600px" background="pic/bgjpg”> 
<t> 
<td> 
<table align="center"> 


<td> 回 帖 ，<input type="hidden" name="ID" value="1081" /></td> 
<td> 标 题 ，<input type="text” /></td> 
<td> 内 容 : <textarea cols="30" rows="3"></textarea></td> 


<td><input class="one" type="submit" name="sub" value=" /></td> 


<tr><td id="name" style="display:none"> 
隐藏 域 值 为 ，<b id-"bl"></b><br> 标 题 值 为 ，<b id="b2"></b><br> 内 容 值 为 ，<b id="b3"></b> 
</td></t> 


(2) 编写 JavaScript 脚本 ， 当 单 击 “ 回 帖 ” 按 钮 时 触发 事件 ， 代 码 如 下 : 
$(document).ready(function0 上 
$(".one").click(functionO{ 
var vall = $("input:eq(0)").valO; 
val2 "input:eq(1)").val(|); 
Var val3 = $("textarea").val|; 
S$("#name").css("display","block"); 
S$("#b1").html(vall); 
S$("#b2") html(val2); 
S$("#b3") html(val3); 


D; 
D; 
图 秘笈 心 法 
心 法 领悟 174: jQuery 中 使 用 $(*).html0 方 法 的 注意 事项 。 
此 方法 是 取得 第 1 个 匹配 元 素 的 html 内 容 。 这 个 函数 不 能 用 于 XML 文档 ， 但 可 以 用 于 XHTML 文档 。 
高 级 | 
dle bd we 


力 实例 说 明 


在 很 多 网 站 的 主页 布局 中 ， 程 序 员 除 了 在 导航 栏 中 布置 一 些 按钮 外 ， 在 网 页 的 主体 部 分 中 很 少 出 现 类 似 于 
提交 的 按钮 ， 这 样 做 的 主要 目的 并 不 是 因为 网 页 中 不 再 需要 按钮 ， 而 是 被 一 些 超 链接 或 者 图 像 域 跳 转 所 替代 。 
运行 本 实例 ， 当 单 击 图 片 时 实现 表单 提交 ， 如 图 3.31 所 示 。 
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图 像 护 花 代 提交 按钮 

标题: | 同 开 从 

半日 或 在 有 限 公 可， 苦 一 司 人 乔 
家 知名 企业 

内 容 ， 习 
标题 ， 明 日 软件 内 容 : 明日 坎 件 有 限 公 司 ， 是 一 
家 知名 企业 


a 


图 3.31 图 像 域 代替 提交 按钮 


图 关键 技术 
本 实例 主要 是 利用 JavaScript 代码 ， 通 过 单 击 事件 完成 数据 的 提交 操作 ， 其 关键 代码 如 下 : 
S$(document) .ready(functionO{ 
S$("img").click(functionO){ 


varinput = $("input").valO: 
Var textarea = $("textarea").val(); 
这 input 一 ”|| textarea — ""){ 
alert(" 文 本 框 为 室 " 
Jelse{ 
S$(".n").css("display","block"); 
SC"#").html(input); 
S$("#t").html(textarea); 
} 
»; 
ba 


图 设计 过 程 
(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text/javascript" sre="js/in.js"></script> 
<table width="319" align="center"> 
<t> 


<td width="296" class="o0"> 图 像 域 替 代 提交 按钮 </td> 
</t> 


<t> 
<td> 标 题 : <input type="text" /></td> 
</tr> 


<td> 内 容 : <textarea cols="20" rows="3"></textarea>&nbsp:&nbsp:<img src="pic/img.gif" /></td> 
<tr> 


<td class="n"> 标 题 ，<b id="i"></b> 内 容 : <bid="t></b></td> 
<ltr> 
</table> 
(2) 编写 JavaScript 脚本 文件 mn.js， 当 单 击 图 标 时 触发 事件 ， 代 码 如 关键 技术 所 示 。 
图 秘笈 心 法 
心 法 领悟 175: 图 像 域 的 使 用 。 


使 用 图 像 域 进 行 跳 转 和 提交 的 方式 有 很 多 。 例 如 嵌入 到 <a> 标 签 中 ， 进 行 客户 端 跳 转 ， 或 者 应 用 在 <form> 
表单 的 提交 、 重 置 按钮 中 。 灵 活 运 用 图 像 域 的 知识 会 使 您 的 程序 更 美观 。 
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高 级 
趣味 指数 ， 合 寅 请 病 : 


| 
| 


实例 176 


图 实例 说 明 


跳 转 菜 单 在 网 站 中 是 很 常见 的 ， 一 般 被 放置 在 靠近 头 部 的 位 置 ， 又 称 导航 栏 。 下 面 就 向 用 户 讲解 如 何 实现 
单 击 按钮 页 面 跳 转 的 效果 ， 如 图 3.32 所 示 。 


FANXING 风 结 硬盘 设 为 首页 /加 入 收 本 / 联系 我 们 


首页 | 注册 | 登录 | 论坛 


= pe 1 
| CE 硬盘 图 片 文件 去 

口 巷 目 标题 [nd 点 击 数 Ny TU PAN 

口 。 标题 位 置 收 置 处 ti0 3330 ™ ~ 
更 盘 联 系 方式 

口 。 标题 位 置 放 置 处 10 3330 和 = 

口 。 标题 位 置 放 置 处 i110 3330 -= 
硬盘 电子 图 书 

口 标题 位 置 放 秆 处 i110 3330 人 

口 。 标题 位 置 收 村 处 i110 3330 NN wa 

口 。 标题 位 置 收 置 处 i110 3330 

口 。 标题 位 置 放置 处 i110 3330 

口 。 标题 位 置 放置 处 i110 3330 

共有 2 页 ,当前 是 第 1 页 -FF 

服务 热线 : 0431 


Cop 


图 3.32 跳 转 菜 单 实现 页 面 跳 转 


图 关键 技术 


本 实例 主要 通过 <map> 定 义 跳 转 ， 本 实例 实现 跳 转 的 代码 如 下 : 
<map name="Map2" id="Map2"> 

<area shape="rect" coords="89.64.141.94" href="index.php?id=1" /> 

<area shape="rect" coords="168.64.229.94" href="index.php?id=2" /> 

<area shape="rect" coords="250.65.305.99" href="index.php?id=3" /> 

<area shape="rect" coords="328.63.388.97" href="index.php?id=4" /> 

<area shape="rect" coords="13.65.61.93" href="index.php" /> 
</map> 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 网 页 ， 通 过 <map> 定 义 页 面 跳 转 的 超 链接 。 
(2) 编写 PHP 代码 ， 当 单 击 不 同 按钮 时 实现 跳 转 ， 代 码 如 下 : 
<2php 


switch($_GET[idD){ 
case "1"; 
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} 
?> 


图 秘笈 心 法 


心 法 领悟 176: 如 何 取得 地 址 栏 参数 。 
以 本 实例 为 例子 ， 地 址 组 成 格式 如 下 所 示 ， 可 以 通过 $_ GET 方式 取得 相应 的 参数 并 进行 操作 。 


http:// 地 址 /主页 .php? 参 数 & 参 数 
OE SO 1 
高 级 
S | 
实例 177 趣味 指数 : 依 窗 请 商 


力 实例 说 明 


上 传 图 片 时 最 好 为 程序 设置 预览 功能 ， 防 止 用 户 意外 传 错 图 片 。 还 有 一 个 很 重要 的 模块 就 是 获取 图 片 的 地 
址 ， 方 便 用 户 网 站 的 推广 。 运 行 本 实例 ， 完 成 预览 图 片 和 获取 图 片 地 址 的 功能 ， 运 行 结果 如 图 3.33 所 示 。 


项 目 由 心 - 妇 

提供 详细 的 项 目 开 发 过 程 讲解 ， 包 括 对 开发 背景 、 需 求 分 析 、 系 统 功能 分 析 ， 
可 行 性 分 析 、 

模块 开发 及 系 纺 


图 3.33 上 传 预览 图 片 


图 关键 技术 
本 实例 通过 JavaScript 的 click 事件 ， 实 现 图 片 预 览 、 获 取 地 址 和 清除 上 传 文本 框 信息 的 功能 ， 其 核心 代码 
如 下 : 
S$(document) .ready(functionO{ 
S$("#two").click(fimctionO{ // 单 击 预 览 图 片 
var value = $("#one").valO: // 取 得 上 传 地 址 
iflvalue — "){ /判断 地 址 是 否 为 空 
alert(" 地 址 为 室 "): 
jelse{ 
S$(".n").append("<img id-'five sre="+value+">"); /显示 图 片 
S$("#two").click(finctionO{ 
S$(".n").emptyO: 


S$(".0").append("<img id=five’ sre="+valuet">"); 
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D; 
; 


D; 
S$("#three").click(functionO{ // 显 示 图 片 地 址 
var value = $("#one").valO; 


D: 
$("#four").click(functionO{ // 清 除 文本 框 信息 
$(".e").emptyO; 
$(".e").append("<input class='one id-'one type='file>"); 
D; 
D; 
设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 样式 、inijs 文件 以 及 jQuery 库 文件 jquery-1.3.2js。 创 建 form 表单 ， 
设置 文件 域 属性 ， 添 加 预览 图 片 、 图 片 地址 和 清除 的 按钮 ， 代 码 如 下 : 
<table width="600" height="450" align="center' background="pic/bgjpg"> 
<t> 
<td align="center"><div class="n"></div> 
<table align="center"> 
<t> 
<td> 
<span class="o"> 
<span class="e"><input class="one" id="one" type="file"></span> 
<input class="one" id="two" type=button value=" 预 览 图 片 "> 
<input class="one" id="three" type=button value=" 图 片 地 址 "> 
<input class="one" id="four" type=button value=" 清 除 " > 


</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 177: jQuery 框架 中 的 empty0 方 法 。 

empty0 方 法 :删除 匹配 的 元 素 集合 中 所 有 的 子 节 点 ， 语 法 格式 如 下 : 
Sclass/id').empty0; 

参数 说 明 : 

class/id: 表示 类 名 或 ID 名 称 。 


实例 178 


图 实例 说 明 a | 
由 于 CSS 样式 对 下 拉 列表 框 的 定义 很 少 , 以 至 于 想 要 修改 下 拉 列表 的 样式 -一 
变 得 很 复杂 。 本 实例 将 向 用 户 讲解 如 何 去 掉 下 拉 选 项 的 边框 ， 如 图 3.34 所 示 。 


图 3.34 去 掉 下 拉 选 项 的 边框 
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四 关键 技术 


本 实例 的 关键 点 是 严格 定义 CSS 样式 ， 代 码 如 下 : 

<div style="position: absolute; left: 10px; top: 10px; width: 115px: height 20px: clip:rect(2 114 20 2):"> 
图 设计 过 程 

创建 index.php 文件 ， 利 用 <table> 标 签 编写 表格 边框 。 编辑 CSS 样式 , 通过 CSS 样式 去 掉 下 拉 选 项 的 边框 ， 
代码 如 下 : 


‘<table width="200px" height="100px" border="1" bordercolor="#0099FF" cellspacing="0"><tr><td> 
<div style="position: absolute; left: 10px; top: 10px; width: 11Spx: height: 20px: clip:rect(2 114 20 2);"> 
‘<select> 


图 秘笈 心 法 
心 法 领悟 178: CSS 的 效果 。 


像 这 样 较为 生 个 的 代码 ， 其 实 笔者 也 不 能 够 完全 吃透 ， 但 是 没关系 ， 因 为 我 们 所 从 事 的 是 后 台 的 开发 ， 至 
于 前 台 的 东西 ， 多 了 解 一 下 即 可 。 


实例 
实例 179 趣味 指数 : 会 依依 请 


图 实例 说 明 


表单 可 以 添加 属性 并 且 与 客户 端 脚本 JavaScript 交互 ， 例 如 JavaScript 的 click 事件 、change 事件 等 。 运 行 
本 实例 ， 当 单 击 文本 框 时 弹出 提示 信息 ， 如 图 3.35 所 示 。 
Sis 


| 


如 果 在 蝙 程 词典 中 没有 泡 简 要 的 录 人 党 ， 请 及 时 反馈 给 我 们 ,我 们 全 力 安 振 专 家 网 
开发 视频 及 像 。 并 及 时 升级 到 屿 程 询 枢 录像 中 。 


ernet Epler 


3.35 弹出 窗口 


图 关键 技术 


本 实例 主要 是 通过 JavaScript 代码 定义 单 击 事件 ， 核 心 代码 如 下 : 
S$(document) ready(fanction0f 


$C"#o") .click( 


(fanctionO{ 
alert(" 文 本 框 被 单 击 "); 
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D; 
Dp; 
图 设计 过 程 
创建 ndex php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 js 和 jQuery 库 文件 jquery-1.3.2js。 创 建 form 
表单 并 定义 事件 ， 代 码 如 下 : 
<table align="center"> 
<t> 
<td> 用 户 名 : </td> 
<td><input id="0" type="text" /></td> 
<t> 
<t> 
<td> 密 &nbsp;&nbsp; 码 :</td> 
<td><input id="o0" type="text" onclick="alert( 密 码 框 被 单 击 )"/></td> 
nie 


图 秘笈 心 法 


心 法 领悟 179: 定义 JavaScript 事件 。 

如 果 用 户 想 利用 JavaScript 本 身 的 方法 定义 事件 , 需要 在 表单 中 进行 ,代码 格式 如 实例 180 所 示 。 如 果 是 利 
用 jQuery 框架 定义 事件 ， 只 需要 在 标签 中 定义 ID 或 者 类 即 可 。 

<input id="o"type="text" onclick="alert(' 密 码 框 被 单 击 )"/> 


力 实例 说 明 


灵巧 的 CSS 是 所 有 Web 开发 者 追捧 的 对 象 , 其 主要 作用 是 通过 简单 的 代码 美化 页 面 , 页 面 美化 几乎 用 CSS 
都 可 以 实现 。 本 实例 主要 讲解 通过 定义 CSS 样式 对 输入 单元 的 文字 进行 设置 ， 如 图 3.36 所 示 。 
[FI | 


用 户 名 : FE 
密码 ;|asd 


3.36 动态 改变 文字 颜色 


图 关键 技术 


本 实例 的 关键 点 是 定义 CSS 样式 ， 通 过 JavaScript 代码 动态 地 改变 文本 框 的 颜色 。JavaScript 代码 如 下 : 
<script type="text/javascript" language="javascript"> 
S$(document).ready(functionO{ 
S$("select").change(functionO){ 
var value = $("select").valO; 


这 value — ""){ 
alert(" 请 选择 样式 颜色 "); 
jelsef 
SC"input:lt(2)").css("color",value): 
D: 
D; 
</script> 
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图 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 CSS 样式 定义 一 个 无 边框 的 下 拉 列 表 ， 代 码 如 下 : 
<div style="position: absolute: left 10px: top: 10px; width: 115px: height 20px: clip:rect(2 114 20 2):"> 
<selec> 


<div> 

(2) 编写 文本 框 和 密码 框 ， 代 码 如 下 : 
<div style="font-family:' 楷 体 _GB2312'; font-size:16px;"> 
用 户 名 : <input type="text" /><br> 


密 &nbsp:&nbsp: 码 : <input type="text" /> 
</div> 


(3) 编写 JavaScript 脚本 文件 injs， 动 态 改变 文本 框 输入 单元 颜色 ， 代 码 如 关键 技术 中 所 示 。 
力 秘笈 心 法 


心 法 领悟 180: jQuery 中 匹配 所 有 小 于 给 定 索引 值 的 元 素 。 
格式 ， 例 如 $C"tr:1t(2)")， 匹 配 标签 <u> 中 小 于 索引 值 2 的 元 素 。 


实例 181 


图 实例 说 明 


在 创建 表单 中 的 文本 框 等 内 容 时 ， 往 往 会 给 文本 框 设 定 初始 值 ， 这 些 初始 值 需要 用 户 自行 手动 删除 。 为 了 


方便 用 户 ， 节 省 操作 时 间 ， 可 以 通过 设置 JavaScript 事件 ， 实 现 直 接 删除 文本 框 中 初始 值 的 功能 。 运 行 本 实例 ， 
如 图 3.37 所 示 。 


如 果 在 蝙 程 词典 中 没有 六 需要 的 录像， 请 及 时 反馈 给 我 们 ,我 们 全 力 安 振 尖 家 出 
开发 视频 录像， 并 及 时 升级 到 篇 程 词 英 录 像 中 。 
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alert( 清 除 文本 框 信息 人 ); 
D; 
S$("textarea").click(function){ 
S(this).attr("value",""); 
入 


设计 过 程 
创建 index.php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 injs 和 jQuery 库 文 件 jquery-1.3.2js。 编 写 表 单 
信息 ， 代 码 如 下 : 
<table align="center"> 
<t> 


<td> 标 题 : </td> 
<td><input type="text" value=" 请 输入 标题 " ></td> 
<t> 


<t> 
<td> 内 容 : </td> 
<td><textarea cols="23" rows="3"> 请 输入 内 容 </textarea></td> 
<> 
</table> 


图 秘笈 心 法 
心 法 领悟 81， 如 何 简单 实现 本 实例 功能 。 


本 实例 是 采用 jQuery 框架 实现 的 ， 书 写 代码 较 多 ， 还 有 一 种 简便 方法 是 在 表单 中 直接 定义 onFocus 事件 ， 


代码 如 下 : 
<input type='text name='te' value=' 请 输入 内 容 ' onFocus="this.value=""> 
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力 实例 说 明 


很 多 网 站 中 ， 往 往 有 一 些小 的 技巧 ， 例 如 ， 在 文本 域 中 输入 内 容 时 ， 通 过 下 拉 列 表 动 态 地 将 文字 插入 到 文 
本 域 中 。 下 面 就 向 用 户 讲述 这 一 功能 。 运 行 本 实例 如 图 3.38 所 示 。 


如 果 在 编程 词 此 中 没有 您 涯 要 的 录 谷 ， 请 及 时 反馈 给 我 们 ， 我 们 全 力 安 皇 专家 凋 | 
开发 视频 录 娩 ， 并 及 时 升 奴 到 久 程 油 甘 录像 中 。 


~ i 


图 3.38 表单 文本 输入 的 移动 选择 


图 关键 技术 


本 实例 通过 JavaScript 脚本 中 的 change 事件 ， 实 现 动态 插入 信息 ， 其 核心 代码 如 下 : 


a 
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S$(document) ready(finctionO{ 
S$("textarea").select|): /选择 下 拉 列 表 
S$('select").change(function0{ /定义 事件 
var value = $(this).valO; /获取 value 值 
Var va = $("textarea”).valO; /获取 文本 域 的 值 
这 va 一 "请 输入 内 容 "){ 
S$("textarea").html(value); /输出 文本 域 的 值 
Jelse{ 
S$("textarea").html(vatvalue); // 为 文本 域 赋值 
. 
D; 
D; 
图 设计 过 程 


(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 js， 以 及 jQuery 库 ， 创 建 下 拉 列 表 框 和 
文本 域 ， 代 码 如 下 : 


<table align="center"> 
<t> 
<td><select name="select"> 
<option value=" 谢 谢 "> 谢 谢 </option> 
<option value=" 不 客气 "> 不 客气 </option> 
<option value=" 有 空 常 来 玩 "> 有 空 常 来 玩 </option> 
<option value=" 再 见 "> 再 见 </option> 
‘</select></td> 
</tr> 
<t> 
<td><textarea cols="20" rows="3"> 请 输入 内 容 </textarea></td> 


he 
(2) 编写 JavaScript 脚本 文件 injs， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 182: 如 何 利用 jQuery 实现 文本 框 内 容 全 选 。 
实现 文本 框 内 容 全 选 与 单 击 文本 框 清除 所 有 信息 所 达到 的 效果 大 同 小 异 ， 其 实现 代码 如 下 : 
S$("textarea").selectO; 


力 实例 说 明 


在 腾讯 的 QQ 系统 中 ， 我 们 可 以 通过 单 击 头像 实现 更 换 新 头像 的 功能 。 其 实 这 个 功能 相对 来 说 是 比较 简单 
的 。 运 行 本 实例 ， 通 过 下 拉 列 表 实 现 头像 的 选择 ， 如 图 3.39 所 示 。 


图 3.39 选择 头像 
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图 关键 技术 


本 实例 通过 JavaScript 的 change 事件 和 实例 162 中 的 2 级 联动 菜单 实现 ， 其 核心 代码 如 下 : 
S$(document) ready(functionO{ 
S$("select").change(functionO{ 


S("#0").emptyO; 


SC#o").append("<select id-'one><option value='pic/1.jpg> 头 像 1</option><option value='pic/2.jpg> 头 像 2</option><option 
value='pic/3.jpg> 头 像 3</option><option value=pic/4jpg> 头 像 4</option><option value='pic/9jpg> 头 像 5</option></select>"); 
S$("#n").emptyO|); 
S("‘#n").append("<img sre='pic/1 jpg>"); 
S$("#one").change(functionO{ 
var va = $(this).val(); 
S("#n").emptyO); 
S("#n").append("<img sre="+vat">"); 
D; 
jelsef 


Sor)empty0: 


S$("#o").append("<select id-'one><option value=pic/5jpg> 头 像 1</option><option value=pic/6jpg> 头 像 2</option><option 
value=' pic/7jpg> 头 像 3</option><option value=pic/8jpg> 头 像 4</option><option value=pic/10jpg> 头 像 5</option></select>"); 
S("#n").emptyO; 
S("#n").append("<img sre='pic/5.jpg>"); 
S$("#one").change(functionO{ 
var va = $(this).valO; 
S("#n").emptyO; 
S("#n").append("<img sre="+vat">"); 
3 


D; 
D; 


设计 过 程 


<table align="center"> 
<t> 


<td> 
<select name="select"> 
<option value=""> 请 选择 性 别 </option> 
<option value="nan"> 男 性 </option> 


<option value="nv"> 女 性 </option> 
</select> 


(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs， 以 及 jQuery 库 ， 编 写 下 拉 列 表 和 标 
签 ， 代 码 如 下 : 


<div id="0"></div><div id="n"></div> 
<t> 
</tr> 


</table> 


(2) 编写 JavaScript 脚本 文件 in.js， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 183: jQuery 中 的 this 关键 字 。 


var va = Sthis) val0: 


jQuery 中 的 this 关键 字 与 其 他 编程 语言 大 致 相同 ,此 关键 字 表 示 当 前 方法 体 的 类 名 称 或 者 ID 和 标签 , 书写 
格式 如 下 : 
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3.5 CSS+DIV 页 面 布局 


CSS+DIV 是 一 种 网 站 的 标准 或 称 面向 Web 的 标准 ) 中 常用 术语 之 一 ， 通 常 是 为 了 说 明 与 HTML 页 面 中 
的 表格 (table) 定位 技术 的 区 别 , 或 者 是 因为 HTML 网 站 设计 标准 中 , 不 能 使 用 表格 定位 技术 , 而 采用 CSS+DIV 
方式 实现 的 各 种 定位 。 


高 级 
起 中 相约; 全 高 衣 室 | 


图 实例 说 明 


对 于 一 个 页 面 风 格 清新 自然 的 网 站 来 说 , 如 果 打开 的 窗口 带 有 不 适合 页 面 风格 的 灰色 边框 及 死板 的 标题 栏 ， 
不 但 不 能 体现 其 个 性 化 ， 而 且 势 必 会 影响 网 站 的 整体 效果 。 本 实例 介绍 一 种 应 用 CSS+DIV 实现 的 无 边框 窗口 。 
运行 本 实例 ， 单 击 “ 用 户 登 录 ” 超 链接 ， 即 可 打开 无 边框 的 用 户 登 录 窗 口 ， 如 图 3.40 所 示 。 


5 加 


图 3.40 无 边框 窗口 


图 关键 技术 


本 实例 通过 CSS+DIV 排版 定位 技术 ， 将 表格 放置 在 指定 位 置 ，CSS 代码 如 下 : 


margin: 10px 10px 10px 10px; 
width: 
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margin-right: 10px; 
width:200px: 
height:100px: 
margin:auto; 

} 

#border{ 
width:auto; 

height: 100px; 

} 

#href{ 

clear:left: 
float:right:; 
position:absolute;; 
margin:40px 10px 300px 200px; 
width:80px: 
height:20px; 


} 
并 利用 JavaScript 代码 实现 表格 的 显示 或 隐藏 ，JavaScript 代码 如 下 : 
S$(document) .ready(functionO{ 
$("a").click(functionO{ 
S$("table").css("display","block"); 


和 

S$("#two").click(functionO{ 
S$("table").css("display","none"); 

D; 

D; 


AI 
图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 和 JavaScript 脚本 文件 ， 通 过 <div> 标 签 对 网 页 进行 布局 ， 编 
写 无 边框 表格 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
‘<script type="text/ijavascript" src="js/in.js"></script> 
<div id="container"> 
<div id="border"> 
<div id="href> 
<a href="#"> 用 户 登录 </a> 
</div> 
</div> 
<div id="NOborder"> 
‘<table border="1" bordercolor="#999999" cellspacing="0"><tr><td> 
<table> 
<t> 
<td> 一 用 户 登录 一 </td> 
</t> 


<t> 
<td> 用 户 名 : <input type="text" size="10"/></td> 
</a> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <input type="text" size="10" /></td> 
</tr> 
<t> 
<td><input id="one" value="" type="button" /><input id-"two" value="" type="button" /></td> 


<div> 


(2) 编写 CSS 样式 文件 in.css 和 JavaScript 脚本 文件 in.js， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 
心 法 领悟 184: CSS 中 的 position 关键 字 的 使 用 。 
position: 检索 对 象 的 定位 方式 。 
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参数 说 明 : 

static: 无 特殊 定位 ， 对 象 遵循 HTML 定位 规则 。 

Absolute: 将 对 象 从 文档 流 中 拖 出 , 使 用 left、 right、 top、bottom 等 属性 进行 绝对 定位 , 而 其 层 营 通过 z-index 
属性 定义 。 此 时 对 象 不 具有 边 距 ， 但 仍 有 补 白 和 边框 。 

Telative: 对 象 不 可 层 营 ， 但 将 依据 left、right、top、bottom 等 属性 在 正常 文档 流 中 偏 移 位 置 。 

fixed: 正 5.5 及 NS 6 尚 不 支持 此 属性 。 
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图 实例 说 明 


表格 在 Web 开发 中 非常 常见 ， 很 多 程序 员 都 喜欢 利用 表格 对 自己 数据 库 中 的 信息 进行 格式 输出 。 但 是 表格 
在 默认 情况 下 ， 无 论 从 色调 还 是 格式 上 都 不 是 很 理想 ， 这 就 需要 程序 员 利用 CSS 的 知识 对 表格 样式 进行 设置 。 
运行 本 实例 ， 如 图 3.41 所 示 。 


on 2010-08-12 
002 | pkh | | 2010-08-23 
003 | lzh | | 2010-07-06 


图 3.41 设置 表格 样式 


图 关键 技术 
本 实例 利用 CSS 样式 ， 对 表格 的 边框 、 背 景色 等 进行 设置 ， 核 心 代码 如 下 : 


body{ 
0 


#o{ 
margin-left:150px:; 
} 


table.select{ 
font-family:" 楷 体 _GB2312"; 
font-size:16px: 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 in.css， 利 用 <div> 标 签 设计 网 页 框架 ， 代 码 如 下 : 


<div id="0"> 
<div id="banner"> 

<img sre="pic/banner jpe” > 
<div> 
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<divid="e"> 
<table width="575" border="1" bordercolor="#7DD5FA" cellspacing="0"><tr><td> 
<table width="575px"><tr> 

<td> 用 户 ID</td> 


</table></td></tr></table> 


(2) 编写 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 185: 使 用 CSS 中 margin 关键 字 的 注意 事项 。 

(1) margin 关键 字 主要 用 于 检索 和 设置 对 象 四 边 的 外 沿边 距 ,但 是 此 关键 字 根据 传 入 参数 的 不 同 ， 性 能 也 
不 相同 。 如 果 提 供 全 部 4 个 参数 值 ， 将 按 上 、 右 、 下 和 左 的 顺序 作用 于 四 边 ; 如 果 只 提供 1 个 ， 将 用 于 全 部 的 
四 边 ， 如 果 提 供 2 个， 第 1 个 用 于 上 和 下 ， 第 2 个 用 于 左 和 右 ; 如 果 提 供 3 个 ， 第 1 个 用 于 上 ， 第 2 个 用 于 左 
和 右 ， 第 3 个 用 于 下 。 

(2) 内 联 对 象 要 使 用 该 属性 ， 必 须 先 设 定 对 象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 
在 正 4+ 中 ，margin 属性 不 可 用 于 td 和 嫌 对 象 。 

(3) 外 延边 距 始 终 透明 。 


趣味 指数 : 会 会 侠 会 


力 实例 说 明 


CSS 之 所 以 受到 很 多 Web 设计 者 的 追捧 ， 是 因为 它 几乎 可 以 实现 所 有 的 基础 美化 功能 ， 图 片 当然 也 不 例 
外 。 运行 本 实例 , 应 用 CSS 样式 实现 图 片 向 左 浮动 、 图 片 向 右 浮动 和 为 图 片 添加 边框 的 功能 , 运行 结果 如 图 3.42 
所 示 。 


图 片 向 右 浮动 ” 司 

二 这 择 图 片 样式 。” | 在 下 同 新 甘地 

图片 向 左 浮动 的 中 年 男人 ,， 听 [六 
掀 不 平 ， 经 常 为 Dey 

为 图 片 深 加 边 框 ” 卡 官 志 人 进行 升 扫 9 


的 较 重 。 而 且 他 胆量 非凡 ， 总 是 戏弄 
| 部 些 达 舍 呈 责 。 在 半 里 富 人 都 寺 怕 
| 他， 这 人 都 喜欢 他 ， 他 的 名 字 串 做 阿 凡 提 。 


图 3.42 设置 图 片 的 样式 
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图 关键 技术 


if(value —"" 
alert(" 您 没有 选择 图 片 样式 "); 
jelsef 
if(value — D{ 
S("img").css("float", "left"); 
Jelse{ 
if(value — 2){ 
Ce S("img").css("float","right"); 


S$("img").css( {border:"1px red solid"}); 


} 
D; 
D; 


图 设计 过 程 

(1) 创建 脚本 文件 ， 利 用 <div> 建 立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 下 拉 列 表 和 内 容 主 
体 ， 代 码 如 下 : 

<div> 


<table border="1" bordercolor="#00CCFF" cellspacing="0"><tr><td> 
<select> 

<option value=""> 请 选择 图 片 样式 </option> 

<option value="1"> 图 片 向 左 浮动 <'option> 

<option value="2"> 图 片 向 右 浮动 </option> 

<option value="3"> 为 图 片 添加 边框 </option> 
</select> 
<ltd></tr><tr><td> 

<img sre="pic/img.gif" /> 

&nbsp:&nbsp:&nbsp:&nbsp: 很 久 很 久 以 前 ， 在 中 国 新 疆 地 区 ， 有 一 个 骑 着 毛驴 的 中 年 男人 ， 听 说 他 智慧 过 人 ， 爱 打 抱 不 平 ， 经 常 为 了 
老百姓 的 利益 与 达官 贵人 进行 智慧 的 较量 。 而 且 他 胆量 非凡 ， 总 是 戏弄 那些 达官 显贵 。 在 那里 富 人 都 害怕 他 ， 穷 人 都 喜欢 他 ， 他 的 名 字 叫 做 阿 
凡 提 


<ltd></tr></table></div> 
(2) 编写 JavaScript 脚本 ， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 186: CSS 中 如 何 使 用 float 属性 。 

float 属性 指定 对 象 是 否 浮动 和 如 何 浮动 等 ， 参 数 如 下 : 
nne: 对 和 象 不 浮动 。 

left， 对 象 浮 在 左边 。 

right: 对 象 浮 在 右边 。 


力 实例 说 明 


用 户 在 设计 页 面 时 ， 为 了 达到 整体 协调 的 效果 ， 很 多 时 候 需 要 重新 设计 滚动 条 。 本 实例 只 是 更 改 了 滚动 条 
相关 的 色调 ， 没 有 对 其 整体 效果 进行 更 改 ， 运 行 效果 如 图 3.43 所 示 。 
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居 es 天 下 鲜 人 网 


[1 
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美食 教程 


T 鸡 杖 牛 内 上 : 牛 闪 一 各 ， 孜 然 少许 ， 放 入 牛 内 及 调味 刑 ， 少 中 火 炒 节 再 放 入 孜 兰 即 可 入 查 。 
| 到 


国 


图 3.43 滚动 条 样式 
图 关键 技术 
本 实例 通过 CSS 样式 ， 对 浏览 器 的 滚动 条 等 颜色 进行 更 改 ， 核 心 代码 如 下 : 
tdffontrsize:9pt} 
BODY { 


SCROLLBAR-BASE-COLOR: #FFADO0; 
SCROLLBAR-FACE-COLOR: #FFCB29; 
SCROLLBAR-ARROW-COLOR: #800529; 
SCROLLBAR-TRACK-COLOR: #EEFFCC:; 
SCROLLBAR-DARKSHADOW-COLOR:#FFFFFF: 
} 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 页 面 ， 载 入 CSS 样式 ， 其 关键 代码 如 下 : 
<link href="css/style.css" rel="stylesheet"> 


(2) 编写 CSS 样式 文件 style.css， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 
心 法 领悟 187: ”CSS 中 设置 color 属性 的 注意 事项 。 


color 为 要 设置 的 颜色 代码 ， 可 以 是 十 六 进 制 的 ， 例 如 三 F0000， 也 可 以 是 以 RGB 表示 的 , 例如 RGB (255， 
0，255) 。 在 设置 滚动 条 样式 时 ， 不 必 把 所 有 的 属性 都 用 上 ， 用 户 可 根据 网 页 的 需求 自行 设置 。 


实例 188 


图 实例 说 明 

表单 几乎 是 所 有 网 站 都 不 可 或 缺 的 一 个 模块 ， 用 户 可 以 用 它 来 登录 到 网 站 或 者 填写 个 人 信息 等 。 所 以 对 
于 一 个 Web 开发 者 来 说 , 学 习 设置 一 个 优秀 的 表单 样式 是 很 重要 的 。 运 行 本 实例 ,通过 CSS 设置 表单 样式 ， 如 
图 3.44 所 示 。 


用 上 
窜 码 ooeeed 
SD 


Sk 


图 3.44 设置 表单 样式 
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图 关键 技术 


本 实例 通过 CSS 样式 对 表单 的 字体 、 标 签 、 文 本 边框 进行 设置 ， 实 现 美化 的 目的 ， 代 码 如 下 : 


margin-left:400px; 


background-image:url(../pic/buttom.jpe); 
border:0; 
} 
Hee{ 
width:35px; 
background-image:url(../pic/buttom!1 .jpg); 
border:0; 
} 
#o#n{ 
border: 1px #FFCCFF solid: 
} 
table{ 
width:250px; 
height: 150px; 
ee 
另外 还 应 用 JavaScript 特效 ， 使 鼠标 窗 盖 或 移出 时 文本 框 变色 ， 代 码 如 下 : 
S$(document) .ready(functionO{ 
$("input:lt(2)").mouseover(functionO{ 
S(this).css("background","#BFAFC9"); 
S$(this).mouseout(function){ 
S(this).css("background","white"); 
D; 
D; 
DD: 
设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 、JavaScript 脚本 文件 和 jQuery 类 库 文件 ， 通 过 <div> 定 位 技术 ， 
对 表格 信息 进行 定位 。 创 建 form 表单 ， 设 置 用 户 名 和 密码 文本 框 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" src="../js/jquery-1.3.2.js"></script> 
<script type="text/javascript" src="js/in.js"></script> 
<div> 
<div id="one"> 
‘<table border="1" bordercolor="#00CCFF" cellspacing="0"><tr><td> 
用 户 名 : <input type="text" id="0" /><br> 
密 &nbsp:&nbsp: 码 : <input type="password" id="n" /><br> 
<input type="button" id="e" value=""/><input type="button" id="ee”" value=""/> 
</td></tr></table> 
<div> 
<div> 


(2) 编写 CSS 样式 和 JavaScript 脚本 ， 代 码 如 关键 技术 中 所 示 。 
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图 秘笈 心 法 


心 法 领悟 188: CSS 中 设置 border 属性 的 注意 事项 。 

border 属性 是 复合 属性 ， 如 使 用 该 复合 属性 定义 单个 参数 ， 则 其 他 参数 的 默认 值 将 无 条 件 覆 盖 各 自 对 应 的 
单个 属性 设置 ， 默 认 值 为 medium none。border-color 的 默认 值 将 采用 文本 颜色 。 要 使 用 该 属性 ， 必 须 先 设 定 对 
象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 


EN 


力 实例 说 明 
超 链接 在 Web 开发 中 也 是 很 常见 的 ， 其 主要 作用 是 执行 客户 端的 脚本 跳 转 。 默 认 情况 下 ， 单 击 之 前 颜色 为 


蓝 色 ， 存 在 下 划 线 样式 ， ee 同样 存在 下 划 线 样式 。 但 是 这 种 样式 不 可 能 适合 所 有 的 网 站 色 
调 。 本 实例 介绍 如 何 更 改 超 链接 的 样式 ， 运 行 结果 如 图 3.45 所 示 。 


医 到 
图 3.45 ”设置 超 链 接 的 样式 


图 关键 技术 
本 实例 通过 CSS 样式 ， 定 义 <a> 标 签 的 3 个 属性 ， 控 制 超 链接 的 样式 ， 其 核心 代码 如 下 


af 
border:1px #FF0000 solid; 
} 
alink{f 
Color:#333333; 
text-decoration:none; 
} 
a:Visited{ 
Color:#666666; 
text-decoration:none; 
} 
ahoverf 
0 
color:#FFFFFF: 
} 
设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 ， 编 写 5 个 超 链接 ， 代 码 如 下 : 
<div> 
<div id="one"> 
‘<table border="1" bordercolor="#00CCFF" cellspacing="0" background="pic/bg.jpe”><tr><td> 
<a hre 合 "#"> 链 接 1</a>&nbsp;<a hre 仁 "#"> 链 接 2</a>&nbsp:<a hre 仁 "# > 链接 3</a>&nbsp:<a hre 人 =" 六 > 链 接 4</a>&nbsp;<a hre 合 "#"> 链 接 


4</a>&nbsp:<a hre 仁 "#' > 链接 5</a> 
</td></tr></table> 


(2) 编写 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 
心 法 领悟 189: 定义 <a> 标 签 的 3 个 属 性 。 
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(1) :link: 设置 a 对象 在 未 被 访问 前 的 样式 表 属 性 。 
(2) :visited: 设置 a 对 象 在 其 链接 地 址 已 被 访问 时 的 样式 表 属性 。 
(3) :hover: 设置 对 象 在 鼠标 悬 停 时 的 样式 表 属 性 。 
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图 实例 说 明 


HTML 将 整个 网 页 分 成 头 部 <head> 和 身体 <body> 两 个 部 分 ， 头 部 一 般 包含 标题 和 引入 的 JavaScript 和 CSS 
样式 等 ; 身体 部 分 主要 是 执行 的 代码 ， 其 中 可 以 包含 表格 、 表 单 和 <div> 标 签 等 元 素 。 大 家 都 知道 ， 对 于 <body> 
中 的 元 素 可 以 进行 CSS 的 样式 美化 ， 但 是 如 果 用 户 想 定义 类 似 全 文 的 一 个 文字 的 样式 ， 则 需要 对 每 个 标签 里 输 
出 到 页 面 的 文字 进行 CSS 样式 的 定义 , 这 样 未 免 太 过 麻烦 , 因此 可 以 在 <body> 标 签 中 应 用 CSS 样式 ， 这 样 就 可 
以 对 整个 页 面 中 的 文字 进行 设置 ， 运 行 结果 如 图 3.46 所 示 。 


提供 源码 彻底 查询 ， 快 速 查 找 相关 技术 的 故 
目 应 用 ， 通 过 源 程序 按钮 ， 可 快速 打开 源 恬 
序 ,方便 实效 。 


NA 
SS | 


图 3.46 设置 body 的 样式 


图 关键 技术 
本 实例 通过 定义 <body> 标 签 的 CSS 样式 ， 对 整个 页 面 中 的 文字 及 文字 的 颜色 进行 定义 ， 其 核心 代码 如 下 : 
i 
font-size: 14px; 
color:#666666; 
} 
图 设计 过 程 
(1) 创建 index.php 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 
代码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" src="../js/jquery-1.3.2.js"></script> 
<script type="text/javascript" src="js/in.js"></script> 
<table width="595px" height—"448px" align="center" border="1" bordercolor="#0099FF" cellspacing—"0" background=—"pic/bg.ipg"> 
Se align="center"> 
<t> 
<td> 用 户 名 : <input type="text" id="0" /></td> 
</> 


<t> 
<td> 密 &nbsp;&nbsp: 码 : <input type="password” id="0"/></td> 
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</table> 


(2) 编写 CSS 样式 和 JavaScript 脚本 文件 ， 核 心 代码 如 关键 技术 中 所 示 。 
图 秘笈 心 法 


心 法 领悟 190: 定义 <body> 标 签 属性 的 注意 事项 。 
当 用 CSS 样式 定义 了 <body> 标 签 后 ， 如 果 想 定义 <body> 内 的 元 素 属性 ， 需 要 对 每 个 元 素 进行 更 改 。 
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图 实例 说 明 

在 一 些 大 型 网 站 的 首页 中 ， 为 了 体现 动画 效果 ， 通 常 在 进入 首页 前 添加 一 个 模拟 的 进度 条 ， 通 过 该 进度 条 
实现 打开 网 站 首页 的 前 奏 。 运 行 本 实例 ， 将 自动 加 载 一 个 模拟 的 进度 条 ， 运 行 结果 如 图 3.47 所 示 。 当 进度 条 完 
成 100% 后 ， 自 动 跳 转 到 http:/www.mingrisoft.com 网 站 。 


3.47 模拟 的 进度 条 


图 关键 技术 


本 实例 主要 应 用 循环 语句 控制 进度 条 的 进度 ， 当 进度 条 完成 整个 进度 的 显示 时 ， 自 动 调用 finish0 函 数 ， 
另外 ， att CSS 样式 设置 的 ， 并 应 用 div 层 输出 到 浏览 器 。 


力 设计 过 程 


(1) 应 用 CSS 样式 设置 div 层 及 文字 的 样式 ， 代 码 如 下 : 
<style type="text/css"> 
div{font-size: 9pt} 
夫 0ad {font-size: 9pt: cursor: default position: absolute: display:block:width:402:height:20:top:expression((document.body.clientHeight-50)/2); 
left:expression((screen.width-400)/2); display: block: z-index:100:;background:#EDECE9} 
PX1 {border: 1px solid ;background-color: #FFFFFF:} 
body { 
background-color: #000000; 


} 
.stylel {color: #FFFFO0} 
</style> 


(2) 在 <body> 中 应 用 div 层 设 计 进度 条 ， 应 用 class 为 div 层 引 用 已 定义 的 CSS 样式 ， 并 添加 部 分 说 明文 


字 ， 然 后 ， 应 用 for 循环 语句 限制 进度 条 完成 整个 进度 的 行程 ， 代 码 如 下 : 
<body onload-finishO> 
<div id-load style="background-color:#000000"><span class="style1"> 请 稍 候 ...</span> 
<div class-pxl><img id-line style="background:red" width=14 height=14></div> 
<div class="style1" id-load txt>loading</div> 
<div> 


<?php 
for(Si=-0:$i<500:SitH{ 
> 


231 


PHP 开发 实战 1200 例 (第 I 卷 ) 
<scripPload num("Loading"):</script> 


window.location.href="http://www.mingrisoft.com"; 
} 
</script> 


图 秘笈 心 法 


心 法 领悟 191: JavaScript 脚本 客户 端 跳 转 的 两 种 形式 。 
当 页 跳 转 : 

window.location.href="http://” 

新 页 跳 转 : 

Window.open="http://” 


图 实例 说 明 
在 进行 网 页 排版 时 ， 用 户 可 以 使 用 <table> 标 签 进行 布局 ， 但 是 在 比较 大 的 网 页 中 ， 用 <table> 标 签 布局 会 使 
页 面 代码 变 得 混乱 ,不 容易 解读 , 所 以 笔者 建议 尽量 使 用 <div> 标 签 进行 页 面 布局 。 运行 本 实例 ,如 图 3.48 所 示 。 
项 目 由 心 
提供 源码 彻底 重 询 ， 快 速 章 找 相关 技术 的 历 


目 应 用 ， 通 过 源 程序 按钮 ， 可 快速 打开 源 程 
席 ， 方 更 实效 。 


图 3.48 ”<div> 标 签 设计 用 户 注册 页 面 


力 关键 技术 
本 实例 的 关键 点 是 对 <div> 标 签 定位 的 灵活 运用 ， 及 运用 CSS 样式 控制 页 面 的 样式 ， 核 心 代码 如 下 : 
body{ 
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.one{ 
margin-top:100px; 
width:595px; 

height:448px; 
background:url(../pic/bgjpe); 
} 

input{ 

width:150px; 

height: 18px: 

border-left:0; 

border-top:0; 

border-right:0; 
border-bottom: 1px #CCCCCC solid: 
background:#6BACCC: 

} 

‘two{ 

margin-top:200px; 
margin-left:200px; 
font-family:" 楷 体 _GB2312"; 
font-size:16px; 
color:#0000FF; 


width: os 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 排版 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表 单 ， 代 码 
如 下 所 示 : 


<div class="one"> 
<div class="two"> 
<div> 
上 昵称: <input type="text" /> 
</div> 
<div> 
密码 ;<input type="password" /> 


<div class="three"> 
<input id="pic" type="submit" value="" /> 

</div> 
<div> 
<div> 
(2) 编写 CSS 样式 ， 设 置 文本 标签 和 标签 位 置 定位 ， 代 码 如 关键 技术 中 所 示 。 

力 秘笈 心 法 

心 法 领悟 192: 如 何 定义 文本 框 只 显示 为 一 条 下 滑 线 的 CSS 样式 风格 。 


使 文本 框 只 显示 为 一 条 下 滑 线 的 操作 很 简单 ， 其 原理 是 将 文本 框 的 左 、 右 、 上 边框 的 border 属性 都 设置 为 
0， 站 边框 的 CSS 样式 。 以 本 实例 为 例 ， 代 码 如 下 : 


border-bottom: 1px #CCCCCC solid; 
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趣味 指数 : 机 二 走 页 


图 实例 说 明 


论坛 的 浏览 页 面 ， 相 信 对 于 所 有 用 户 来 说 并 不 陌生 ， 其 主要 功能 是 将 用 户 发 表 的 内 容 供 所 有 人 或 部 分 人 浏 
览 。 本 实例 讲解 的 主要 内 容 并 不 是 如 何 实现 浏览 这 一 功能 而 是 对 浏览 页 面 的 <div> 布 局 。 运 行 本 实例 ， 如 图 3.49 
所 示 。 


帖子 中 心 


图 3.49 论坛 帖子 的 浏览 页 面 
图 关键 技术 


本 实例 的 关键 点 是 利用 <div> 的 定位 技术 对 页 面 进行 合理 布局 ， 其 中 实现 定位 的 div 元 素 控 制 的 代码 如 下 : 


.one{ 


图 设计 过 程 


(1) 创建 脚本 文件 ， 引 入 CSS 样式 ， 连 接 数 据 库 ， 完 成 数据 库 中 数据 的 分 页 输出 ， 代 码 如 下 : 
<div class="one"> 
<div class—"two"> 
<?php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQI False"): // 连 接 数 据 库 
mysql_select_db("db_database03".$conn) or die ("Connect db False"): 
mysql query("SET NAMES UTFS8"): 
Snum= 1; 
Srs = mysql query("select * from tb demo01"): 
Smu = mysql_num rows($rs); 
iflisset($_GET[page]){ 
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Spage =$_GET[pagel: 
Jelse{ 
Spage= 1; 


. 
这 $page< Smu){ / 份 页 
> 
<div class="three"> 
<a href="index.php?page=<?php echo (Spage+1):?>"> 下 一 页 </a> 
</div> 
<?php 
Jelse{ 
?> 
<div class="three"> 
<a href="index.php?page=<?php echo (Spage-1):?>"> 上 一 页 </a> 
</div> 
<?php 
上 
$pag = $page - 1; 
$sqlstr = "select * from tb_demo0l limit $pag,1"; 
S$rss = mysql query($sqlstr); 
Srey = mysql_fetch_array($rss); 
> 
<div class="five"> 
<table width="500px" border="1" bordercolor="#FF0000" cellspacing="0"> /数据 输出 
<t> 
<td width="70px"> 用 户 ID</td><td width="150px"> 标 题 </td><td> 内 容 </td> 
</tr> 
<t> 
<td><?php echo S$rey[id]?></td><td><?php echo Sreyltitle]?></td><td><?php echo Srey[content]?></td> 
<> 
</table> 
</div> 
<div> 
(2) 编写 CSS 样式 ， 代 码 如 下 : 


height: S00px; 
background:url(../pic/bg.ipg); 
} 

‘three{ 

margin-top:200px; 
margin-left:100px; 

} 

td{ 
font-family:" 楷 体 _GB2312"; 
font-size:15px; 
color:#0099FF 


font-family:" 楷 体 _GB2312": 
border-bottom:0; 
border-left:2px #FF0000 solid: 
border-right:2px #FF0000 solid: 
border-top:2px #FF0000 solid: 
} 

alinkf 

text-decoration:none; 
color:#000000: 
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ahover{ 
background-color:#FF0000: 
Color:-#FFFFFF; 

} 


图 秘笈 心 法 


心 法 领悟 193: 什么 是 相对 路 径 与 绝对 路 径 。 

相对 路 径 与 绝对 路 径 是 在 日 常 程序 开发 过 程 中 经 常用 到 的 两 个 概念 。 相 对 路 径 是 指 以 当前 文件 为 参照 物 ， 
其 他 文件 的 位 置 ， 绝 对 路 径 ， 顾 名 思 义 ， 指 文件 的 绝对 位 置 ， 即 文件 在 本 机 中 的 绝对 位 置 。 以 本 实例 为 例 ， 以 
background:url(../pic/bg.jpg); 引 入 背景 图 片 ， 此 路 径 为 相对 路 径 。 


i 
实 | 
实例 194 趣味 指数 : 穴 规 众 座 | 


图 实例 说 明 


所 有 的 Web 开发 者 几乎 都 是 从 最 简单 的 HTML 语言 开始 学 起 ， 所 以 较 <div> 标 签 来 说 ， 程 序 员 更 喜欢 用 
<table> 标 签 来 完成 网 页 框架 的 布局 。 但 是 从 网 站 优化 的 角度 来 说 ，<div> 标 签 确实 优 于 <table> 标 签 。 本 实例 通过 
设计 后 台 管 理 页 面 ， 着 重 阐述 如 何 使 用 <div> 布 局 。 运 行 本 实例 ， 如 图 3.50 所 示 。 
TO 
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图 3.50 后 台 管 理 页 面 


技术 
本 实例 利用 <div> 标 签 进行 网 页 布局 ， 并 利用 CSS 定义 宽 、 高 等 属性 。 实 现 定位 的 核心 代码 如 下 : 
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width:1023px; 
height:600px; 


height:300px; 
background:url(../pic/right.JPG); 
float:right:; 

} 

.ef 
background:url(../pic/down.JPG); 
width: 1023px; 

height:10px; 

} 


图 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 ， 代 码 如 下 : 
iv class="a"> 

i 

<divelass="e"> </div> 

<div class="d"> 

<div> 

<div class="e"></div> 

<div> 
(2) 编写 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 

图 秘笈 心 法 
心 法 领悟 194: CSS 样式 中 ， 如 何 使 文本 或 标签 居中 显示 。 


在 <div> 标 签 定位 中 ， 如 果 想 使 <div> 标 签 内 部 的 内 容 或 标签 居中 显示 ， 可 以 使 用 CSS 中 的 text-align 属性 
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趣味 指数 : 伍 全 全 从 ; 


图 实例 说 明 

在 设计 网 页 的 过 程 中 ， 能 否 控制 好 各 个 模块 的 位 置 是 很 重要 的 ， 而 控制 这 些 模块 的 标签 中 <div> 是 最 常用 的 
标记 。 利 用 <div> 标 签 再 加 上 CSS 对 其 进行 样式 控制 ， 可 以 实现 很 多 效果 。 下 面 就 来 讲述 一 下 <div> 标 签 的 使 用 
特点 和 应 用 技巧 。 运 行 本 实例 ， 如 图 3.51 所 示 。 
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图 3.51 利用 <div> 标 签 布局 


本 实例 用 到 的 属性 包括 margin、width、height、float、clear， 具 体 说 明 如 下 : 

(1) margin: 控制 模块 与 外 边 距 的 距离 。 其 中 ， 如 果 只 定义 1 个 参数 ， 表 示 到 四 边 的 边 距 ， 定 义 3 个 参数 
表示 到 上 、 左 / 右 、 下 的 边 距 ， 定 义 2 个 参数 表示 到 上 /下 和 左 / 右 的 边 距 。 

(2) width: 定义 <div> 模 块 的 宽度 。 

(3) hight 定义 <div> 模 块 的 高 度 。 

(4) float: 指定 <div> 对 象 模块 如 何 浮动 ， 其 中 包括 3 个 参数 : left、right、none， 分 别 表示 向 左 浮动 、 向 
右 浮动 、 不 浮动 。 

(5) clear: 指定 是 否 允 许 浮动 对 象 ， 其 中 包括 4 个 参数 : left、right、both、none， 分 别 表示 清除 左 侧 浮动 、 
清除 右 侧 浮动 、 清 除 两 侧 浮动 、 不 清除 浮动 。 


图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 定 位 技术 设计 网 页 结构 ， 代 码 如 下 : 
<div class="a"> 

<div class="b"> 
<div class="f"></div> 
<div class=—"j"></div> 

</div> 

<div class="c"></div> 

<div class="d"> 
<div class="g"></div> 
<div class="h"></div> 
<div class="i"></div> 


</div> 


(2) 编写 CSS 样式 ， 将 <div> 模 块 定位 到 指定 位 置 并 添加 背景 颜色 ， 代 码 如 下 : 
body{ 


margin:Opx; 
background#CCCCCC: 


加 
四 
基 


height:75px: 
float:right; 

clear:left; 
background:#0099FF; 
} 

Rt 

margin:Spx; 
width:714px; 
height:30px: 
background:#666666; 
} 

df 

margin:Spx; 
width:714px; 
height:400px; 
background:#6699FF: 


height:400px: 
background:#00FFOO: 
float:left: 


height:400px: 
background:#o9FF33: 
float:right; 

} 

ef 

margin:5pX: 
width:714px: 
height:100px: 
background#CC66CC: 
} 

k{ 

margin:5px auto Spx: 
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width:200px: 
height90px: 
background:#FFFFOO; 
} 


图 秘笈 心 法 


心 法 领悟 195: clear 属性 的 具体 应 用 。 
假设 外 部 <div> 标 签 定义 宽度 为 400 个 像素 ， 内 部 定义 的 两 个 <div> 标 签 的 总 宽度 为 450 个 像素 ， 如 果 内 部 
右 侧 的 <div> 标 签 不 能 清除 左 侧 的 浮动 的 话 ， 将 会 产生 换行 效果 。 


右 宽 高 度 自 适应 ) 


力 实例 说 明 

在 比较 小 的 博客 中 ， 网 页 一 般 分 为 上 、 中 、 下 3 个 部 分 ， 中 间 部 分 又 分 左 、 右 两 个 部 分 。 如 果 利 用 HTML 
的 <table> 标 签 实现 ， 则 需要 多 个 <table> 标 签 进行 嵌 套 ， 但 是 如 果 利 用 <div> 标 签 ， 结 构 就 比较 明朗 了 。 下 面 来 实 
现 这 一 实例 ， 运 行 结果 如 图 3.52 所 示 。 


明日 科 接 有 限 公 。 
司 科 


图 3.52 页 面 布局 之 2 列 左 窗 右 宽 高 度 自 适应 


技术 


本 实例 的 关键 点 是 如 何 实现 <div> 模 块 的 高 度 自 适应 。 其 实 实现 这 一 功能 很 简单 ， 只 需要 定义 height 属性 为 
auto 即 可 ， 代 码 如 下 : 

height:auto; 
图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 ， 并 输出 提示 文字 ， 代 码 如 下 : 
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<div class="f"></div> 
<div class="]"></div> 


<div> 
<div class="c"></div> 
<div class="d"> 

<div class="g"> 


明日 科技 <br>PHP 开发 实录 <br> 典 型 模块 大 全 <br> 


<div> 
<div class="h"> 


明 <br> 日 <br> 科 <br> 技 <br> 编 <br> 程 <br> 词 <br> 典 <br> 修 <br> 订 <br> 版 <br> 马 <br> 上 <br> 就 <br> 要 <br> 上 <br> 市 <br> 啦 ! 


</div> 
</div> 
<div class="e"> 


<div class="k"></div> 


<ldiv> 
</div> 

(2) 编写 CSS 样式 ， 
body{ 

margin:Opx; 
background:#CCCCCC; 


height:80px; 


height:auto:; 
background:#00FFO00: 
float:left: 
font-family:" 楷 体 GB2312":; 
font-size: 16px: 

} 


定义 <div> 模 块 的 宽度 和 高 度 ， 并 为 输出 的 文字 定义 样式 ， 代 码 如 下 : 
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font-family:" 楷 体 _GB2312"; 
color-#FFFFFF; 


图 秘笈 心 法 

心 法 领悟 196: 什么 是 高 度 自 适应 。 

所 谓 的 高 度 自 适 应 是 指 根据 文本 内 容 的 多 少 自动 调整 相应 的 高 度 ， 这 样 设置 的 优点 是 ， 可 以 完全 不 浪费 网 
页 空间 ， 而 且 使 页 面 效 果 饱满 丰富 。 高 度 自 适 应 在 网 页 设计 中 被 广泛 使 用 。 


实例 197 


图 实例 说 明 


实例 196 已 经 讲解 了 页 面 布局 中 左 窄 右 宽 的 情况 ， 本 实例 介绍 2 列 固定 宽度 的 实现 方法 。 运 行 本 实例 ， 如 
图 3.53 所 示 。 


图 3.53 页 面 布局 之 2 列 固定 宽度 + 头 部 + 导航 + 尾部 


第 3 章 
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图 关键 技术 


本 实例 设 定 固定 宽度 的 方法 是 定义 width 属性 为 
2{ 


height:300px; 


float:left; 


图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class=' 


固定 值 ， 代 码 如 下 : 


布局 ， 并 输出 提示 文字 ， 代 码 如 下 : 


<div class="g"><hl> 长 春 市 明日 科技 有 限 公司 <hl></div> 


<div class="h"> 明 日 科技 图 书 ， 新 书 上 市 啦 </div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 


(2) 编写 CSS 样式 ， 定 义 <div> 相 关 属 性 ， 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 


margin:Opx: 
background:#CCCCCC: 


Color-#FFFFFF: 


background:#CCCCCC: 
} 

A 

margin:2px: 
width:200px: 
height:75px: 

float:left: 
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height75px: 
float:right; 


margin: Spx auto Spx; 
width: ; 


图 秘笈 心 法 

心 法 领悟 197: float 属性 的 使 用 方法 。 

在 定义 身体 部 分 时 ， 如 果 身 体 部 分 只 有 两 部 分 ， 可 以 利用 float 属性 ， 一 侧 向 左 浮动 ， 一 侧 向 右 浮 动 ， 但 是 
如 果 身 体 部 分 分 为 3 个 部 分 ， 那 么 定义 为 以 左面 起 ， 前 两 个 向 左 浮动 ， 最 后 一 个 向 右 浮动 为 好 。 


者 侧 固定 中 间 自 适应 居中 ) 


实例 198 高 级 


图 实例 说 明 


实例 196 和 实例 197 都 是 以 中 间 为 两 个 模块 进行 布局 。 本 实例 讲解 中 间 为 3 个 模块 的 实例 ， 并 且 实 现 左 右 
侧 固 定 ， 中 间 自 适应 居中 显示 ， 运 行 效果 如 图 3.54 所 示 。 
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3.54 页 面 布 局 之 3 列 左右 侧 固 定 中 间 自 适应 居中 
图 关键 技术 


本 实例 的 关键 点 是 如 何 实现 中 间 模 块 自 适应 居中 。 答 案 很 简单 ， 将 模块 的 margin 属性 设置 为 上 下 方向 与 边 
距 为 5 个 像素 ， 左 右 方向 为 auto 自动 设置 即 可 ， 核 心 代码 如 下 : 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 进行 网 页 定位 布局 ， 其 中 包括 头 部 、 颈 部 、 身 体 部 分 和 脚 部 ， 代 码 
如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f'> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<h1> 长 春 市 明日 科技 有 限 公 司 <hl> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
<div class="i"> 
敬 请 期 待 实战 范例 宝典 
</div> 
<div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
<div> 
<div> 
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(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 宽 和 高 ， 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 
body{ 

margin:Opx; 

background#CCCCCC; 


height:500px; 
background:#FFFFFF: 
font-family:" 经 典 趣 体 简 "; 
font-size: 18px; 
color-#FFFFFF: 


height:8Opx; 
background:#CCCCCC: 
} 

ff 

margin:2px; 
‘width:200px; 
height:75px; 

float:left; 
background:#FF0000: 


width:714px; 
height:300px; 
background:#6699FF; 


height:300px; 
background:#OOFF00: 
float:left; 

} 

hf{ 

margin:Spx auto: 
width:385px: 
height:auto: 
background:#FFCCFF; 
float:left; 


margin:5px; 
width:150px: 
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图 秘笈 心 法 


心 法 领悟 198: 使 数据 居中 显示 的 方法 。 
CSS 样式 中 有 一 个 text-align 属性 ， 相 当 于 使 用 <table> 标 签 中 的 center 属性 ， 可 以 使 页 面 数据 居中 显示 。 


下 es 


实例 
实例 199 趣味 指数 : 请 耸 商 商 


力 实例 说 明 


灵活 地 控制 页 面 中 <div> 标 签 的 宽度 和 高 度 是 使 用 <div> 标 签 的 核心 。 本 实例 实现 身体 部 分 2 列 右 侧 固定 左 
侧 自 适应 宽度 ， 未 知 高 度 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 如 图 3.55 所 示 。 


长 大 市 明日 科技 有 限 公 司 


3.55 页 面 布局 之 2 列 右 侧 固定 左 侧 自 适应 宽度 


图 关键 技术 
本 实例 的 关键 点 是 实现 身体 部 分 左 侧 自 适 应 宽度 且 未 知 高 度 。 实 现 思想 是 设置 width、height 属性 ， 代 码 
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如 下 : 


2{ 

margin:5px; 
width:auto; 
height:auto; 
background:#OOFF00: 
float:left: 

} 


图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建 立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 
<div class="a"> 
<div class="b"> 
<div class="f > 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公司 <hl> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 
(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 
margin:Opx; 
background:#CCCCCC: 


Color:#FFFFFF: 


height:75px: 
float:left: 
background:#FF0000: 
} 

if 

margin:2px; 
width:500px: 
height:75px: 
float:right: 

clear:left: 
background:#0099FF: 
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图 秘笈 心 法 


心 法 领悟 199: 关键 字 auto 的 使 用 。 
在 <div> 标 签 中 ， 如 果 不 知 道 该 标签 的 具体 宽度 和 长 度 或 者 与 四 边 的 距离 ， 可 以 将 这 些 属性 设置 为 auto。 这 
样 一 来 ， 可 以 让 <div> 标 签 的 长 度 和 宽度 自动 调节 。 


固定 右 自 适 宽度 + 底 平 齐 ) 


力 实例 说 明 


利用 <div> 设 计 页 面 时 ， 有 很 多 很 小 的 技巧 ， 灵 活 地 掌握 这 些 技 巧 可 以 使 用 户 对 页 面 设计 潞 然 开朗 。 本 实例 
主要 实现 身体 部 分 的 2 列 左 侧 固 定 右 侧 自 适应 宽度 ， 未 知 高 度 且 底部 平 齐 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 运 行 
效果 如 图 3.56 所 示 。 
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EE] 
长 邦 市 明和 杂 接 有 限 
公司 


图 3.56 页 面 布局 之 2 列 左 固定 右 自 适 宽度 + 底 平 齐 


图 关键 技术 


本 实例 的 关键 点 是 实现 身体 部 分 右 侧 自 适应 宽度 且 示 知 高 度 ， 底 部 平 齐 。 实 现 思想 是 设置 width、height、 
margin 属性 ， 代 码 如 下 : 
hf 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
<div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<h1> 长 春 市 明日 科技 有 限 公司 <hl> 
</div> 
<div class="h"> 
明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <br> 上 <br 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br 注 <br> 
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af 
margin:auto; 

width:700px; 
height:500px; 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size: 18px; 
color-#FFFFFF; 


height:75px; 
float:left; 
background:#FF0000; 


height:75px; 
float:right; 

clear:left: 
background:#0099FF; 
} 

<t{ 

margin:5px; 
width:714px; 


df 

margin:Spx; 
width:714px; 
height:300px; 
background:#6699FF; 


hf 

margin:Spx Spx Opx Spx: 
width:auto: 

height:auto: 
background:#FFCCFF: 
float:right: 
text-align:center; 


height:100px: 
background:#CC66CC: 
} 

kf 

margin: Spx auto Spx; 
width:200px; 
height:90px; 
background:#FFFFO0; 
color:#000000 


} 
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图 秘笈 心 法 


心 法 领悟 200: 属性 margin 与 底部 平 齐 。 
margin 属性 ， 在 实例 185 中 已 经 讲解 过 ， 所 谓 的 底部 平 齐 就 是 指 下 边 距 为 0 像素 ， 所 以 只 要 设置 当前 模块 
的 下 边 距 属性 值 为 0 像素 即 可 。 


实例 201 


图 实例 说 明 


本 实例 是 实例 200 的 对 照 ， 意 在 使 读者 对 <div> 定 位 技术 有 深入 的 了 解 ， 运 行 结果 如 图 3.57 所 示 。 


i | 


姨 站 其 沁 @ 吕 去 贞 森 


图 3.57 页 面 布局 之 2 列 右 固定 左 自 适 宽度 + 底 平 齐 
图 关键 技术 
本 实例 的 方法 与 实例 200 相同 ， 这 里 不 再 獒 述 。 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 
<div class="a"> 
<div class="b"> 


<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 


<div class="g"> 
<h1> 长 春 市 明日 科技 有 限 公司 </h1> 
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明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <br> 上 <br 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br> 注 <br> 
</div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
</div> 
(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 
margin:Opx; 
background:#CCCCCC: 


height:500px: 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size: 18px; 
Color:#FFFFFF:; 


height:300px: 
background:#6699FF; 

} 

2{ 

margin: Spx Spx Opx Spx: 
width:auto; 

height:auto; 
background:#OOFF00: 
float:left; 

} 

h{ 

margin:5px; 
width:320px: 
height:300px: 
background:#FFCCFF: 
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图 秘笈 心 法 

心 法 领悟 201: padding 补丁 边 距 。 

本 实例 中 ， 因 为 设置 底部 平 齐 ， 所 以 右 侧 固 定 宽度 的 的 模块 就 可 能 与 底 边 距 不 是 5 个 像素 的 距离 ， 为 了 整 
体 的 美感 效果 ， 可 以 为 右 侧 模 块 设置 padding 补丁 边 距 ， 设 置 好 合适 距离 后 ， 显 示 效果 如 图 3.57 所 示 。 


3.6 弹出 窗口 


弹出 窗口 经 常 在 网 站 中 使 用 ， 如 弹出 式 广告 或 网 站 公告 ， 及 打开 居中 显示 详细 信息 的 新 窗口 等 。 所 以 掌握 
设计 弹出 窗口 的 技术 ， 也 许 会 给 设计 的 网 站 带 来 额外 的 效益 。 

:>--= > 

窗口 高 级 

趣味 指数 : no 


实例 202 


图 实例 说 明 


JavaScript 这 门 脚 本 语言 的 功能 很 强大 ， 尤 其 是 在 网 页 特效 的 处 理 上 ， 更 是 有 其 独到 之 处 。 本 实例 将 讲述 的 
是 通过 JavaScript 代码 控制 ， 弹 出 指定 尺寸 的 无 边框 窗口 ， 如 图 3.58 所 示 。 


到 起 | 


/a | 


3.58 单 击 跳 转 图 
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图 关键 技术 


本 实例 主要 是 利用 JavaScript 代码 ， 控 制 弹出 窗口 的 尺寸 ， 核 心 代码 如 下 : 

selfresizeTo(250,180); 

width=screen.width; 

height=screen.height; 

selfmoveTo((width-240)/2.(height-139)/2): 
图 设计 过 程 

(1) 创建 脚本 文件 ， 利 用 <div> 标 签 定位 技术 建立 网 页 架构 ， 引 入 CSS 文件 ， 当 单 击 图 标 按钮 时 ， 发 生 跳 
转 ， 代 码 如 下 : 

<div class="a"><img sre="pic/bgjpg” border="0" usemap="#Map" /> 

<map name="Map" id="Map"><area shape="rect" coords="469.298.541.382" href="in.php" /></map> 

<div> 

(2) 创建 脚本 文件 ， 命 名 为 m.php， 此 文件 执行 跳 转 后 的 代码 。 另 外 ， 在 此 文件 中 建立 <form> 表 单 ， 代 码 
如 下 : 


<div class="c"> 
用 户 名 : <input type="text" name= "text"><br> 
密 &nbsp;&nbsp; 码 : <input type="password"><br> 
<input type="button" class="one" value="">&nbsp:&nbsp:<input type="button" class="two"value=""> 
</div> 
(3) 编写 JavaScript 脚本 ， 定 义 网 页 窗口 的 尺寸 并 定义 当 鼠 标 覆 盖 和 移 开 文本 框 时 产生 的 变色 效果 ， 代 码 
如 下 : 
S$(document) ready(functionO{ 
selfresizeTo(250.180); /定义 窗口 的 宽 和 高 
height=screen height: 
self.moveTo((width-240)/2,(height-139)/2); 
S$("input:eq(0)").mouseover(functionO{ // 当 鼠标 米 盖 时 
$("input:eq(0)").css("background","#FFCCFF"); 
S$("input:eq(0)").mouseout(functionO{ // 当 鼠标 移 开 时 
S$("input:eq(0)").css("background","#FFFFFF"); 


D); 
SCinput: ca Dameenyer tunetinn 


‘functionO{ 
S("input:eq(1)").css("background","#FFFFFF"); 


入 


秘笈 心 法 

心 法 领悟 202: HTML 的 <map> 标 签 。 

如 果 用 户 使 用 的 编程 工具 是 Dreamweaver， 那 么 对 于 这 个 标签 应 该 并 不 陌生 ， 此 标签 的 主要 作用 是 当 鼠 标 
单 击 指定 区 域 时 ， 网 页 发 生 跳 转 。 


力 实例 说 明 
通常 用 户 在 使 用 正 浏览 器 浏览 网 页 时 ,浏览 器 窗口 都 是 包括 标题 栏 、 菜 单 栏 和 状态 栏 等 固定 内 容 。 虽 然 菜 
单 栏 和 状态 栏 可 以 通过 设置 而 隐藏 ， 但 是 标题 栏 却 不 能 ， 即 使 将 网 页 全 屏 显示 也 不 能 将 其 去 除 。 有 时 为 了 网 站 
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的 整体 效果 考虑 ， 需 要 将 网 页 设置 为 全 屏 显 示 。 例 如 ， 在 明日 网 络 宽带 影院 网 站 中 ， 为 了 给 用 户 以 更 真实 的 感 
觉 ， 就 可 以 将 整个 网 站 的 主页 面 设置 为 全 屏 显示 模式 ， 如 图 3.59 所 示 ， 从 图 中 可 以 看 出 该 页 面 中 还 设计 了 “ 退 
出 ” 超 链接 ， 可 以 方便 浏览 者 随时 离开 影院 ， 这 也 是 设计 全 屏 显 示 时 需要 注意 的 问题 ， 否 则 浏览 者 会 因 找 不 到 
出 口 而 烦恼 。 


Se 


图 3.59 全 屏 显 示 


力 关键 技术 


本 实例 主要 通过 window 对 象 的 open0 方 法 ， 并 借助 一 个 中 转 页 实现 ， 当 中 转 页 运行 时 调用 open0 方 法 打 
开 一 个 全 屏 显 示 的 窗口 〈 使 用 window 对 象 的 open0 方 法 中 的 参数 fullscreen=1 实现 ) ， 并 关闭 打开 中 转 页 的 
窗口 。 


图 设计 过 程 
新 建 一 个 空 的 PHP 页 面 (页 面 中 可 以 没有 任何 页 面 布 局 元 素 或 内 容 )， 命 名 为 index.php。 该 页 面 只 是 起 到 


一 个 页 面 跳 转 的 作用 ， 主 要 应 用 Javascript 脚本 自 定义 一 个 MM_c0 函 数 ， 并 应 用 window 对 象 的 open0 方 法 打 
开 一 个 新 的 formal.htm 页 ， 设 置 参数 fnllscreen=1， 从 而 实现 打开 窗口 的 全 屏 显 示 ， 代 码 如 下 : 


<object type="application/x-oleobject" id-closes classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11"> 
value="close"> 


图 秘笈 心 法 


心 法 领悟 203: 全 屏 显示 的 主要 应 用 。 
用 户 在 浏览 类 似 于 土豆 、 优 酷 等 网 站 的 视频 时 ， 经 常会 看 到 播放 器 的 下 方 存在 一 个 全 屏 显 示 的 按钮 ， 其 实 
现 方法 与 本 实例 大 同 小 异 ， 只 不 过 使 用 的 控制 方法 不 同 而 已 。 


sm 
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实例 204 


图 实例 说 明 


在 网 站 开发 过 程 中 ， 用 户 经 常 要 求 在 客户 端 应 用 自 定义 颜色 来 改变 某 些 信息 或 控件 等 的 颜色 值 ， 如 留言 本 
中 的 文字 颜色 、 控 件 背 景色 等 ， 通 过 在 网 页 中 加 入 一 个 网 页 拾 色 器 即 可 实现 。 运 行 本 实例 ， 将 在 页 面 中 显示 如 
图 3.60 所 示 的 网 页 拾 色 器 ， 当 用 户 单 击 颜色 块 时 ， 就 会 弹出 一 个 提示 框 ， 提 示 其 所 选 的 颜色 值 是 多 少 ， 通 过 选 
择 的 颜色 值 来 改变 网 页 的 背景 色 。 


图 3.60 网 页 拾 色 器 


图 关键 技术 


本 实例 的 关键 点 是 在 实现 网 页 拾 色 器 时 ， 应 用 JavaScript 的 数组 。 创 建 数组 有 以 下 3 种 方法 : 
(1) 无 参数 调用 ， 语法 格式 如 下 : 


varh=new 


(2) 指定 数组 前 n 个 元 素 的 值 ， 语 法 格式 如 下 : 
var h = new Array(arglist); 


其 中 参数 arglist 是 一 个 用 逗号 隔 开 的 值 表 ， 这 些 值 用 于 给 variant 所 包含 的 数组 的 各 元 素 赋值 。 如 果 不 提 供 
参数 ， 则 创建 一 个 长 度 为 0 的 数组 。 


(3) 指定 具有 的 元 素 个 数 ， 语 法 格式 如 下 : 
var h=new Amay(n): 
其 中 参数 n 是 指定 数组 的 长 度 。 由 于 在 JavaScript 中 ， 数 组 的 第 1 个 元 素 的 下 标 值 为 0， 所 以 的 值 为 数组 
的 最 大 下 标 值 加 1。 


力 设计 过 程 
(1) 创建 需要 调用 网 页 拾 色 器 的 页 面 ， 在 该 页 面 中 添加 一 个 文本 框 ， 将 文本 框 设置 为 只 读 ， 同 时 将 文本 框 
的 背景 颜色 设置 为 黑色 ， 并 在 该 文本 框 的 onClick 事件 中 调用 自 定义 的 JavaScript 函数 colorpick0， 代 码 如 下 : 


<input name="color" type="text" id="color”" size="3" readonly="yes" style= "background-color#CCFF00" onClick="colorpick(this):"> 


(2) 编写 自 定义 的 JavaScript 函数 colorpick0， 用 于 打开 网 页 对 话 框 调用 网 页 拾 色 器 ， 并 用 网 页 拾 色 器 的 
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值 设 置 文本 框 的 背景 颜色 和 网 页 的 背景 颜色 ， 代 码 如 下 : 
<scriptlanguage="javascript > 
firnction colorpick(field) { 
var rtn = window.showModalDialog("color. php",™"."dialogWidth:225px: dialogHeight:170px:status:no:help:no:scrolling—no:scrollbars—no"); 
if(rin!=null) 
document body style background=rtn: 
fieldstyle background-rtn: 
retum 
UL 
</script> 
(3) 制作 网 页 拾 色 器 页 面 color.php， 关 键 代码 如 下 : 
<script language—"JavaScript"> 
var h = new Array(6) 


向 
加 


h[ 
function action(RGB) { 
parent.window.retumValue="#"+RGB; 
window.close(); 
} 
function Mcell(R, G, B) { 
document.write('<td bgcolor="# +R+ G+B+">"); 
document.write('<a href="#" onClick="action(\" + (R + G+ B)+\)">"); 
document.write(‘<img border=0 height=12 width=12 \)" alt=\#+R+G+B+\>"); 
document.write("</a>"); 
document.write('</td>"); 
} 
function Mtr(R, B) { 
document.write('<tr>"); 
for (vari=0;i<6; Hi) { 
Mecell(R, hli], B); 
} 
document.write('</tr>") 


} 

function Mtable(B) { 
document.write('<table cellpadding=0 cellspacing=0 border=0>"); 
for (vari=0;i<6: ++i) { 
人 B): 

document.write('</table>"); 


} 
function Mcube() { 
‘document.write('<table cellpadding=0 cellspacing=0 border=0><tr>"):; // 
for (vari=0;i<6: Hi) { 
if(i%3=—0){ 
document.write('<tr>"); 


. 
document.write('<td bgcolor="#FFFFFF">"): 
Mtable(h[i]) 
document write('</td>"); 
. 
这 i963 一 0){ 
document.wWrite('</tr>): 
} 
document.write('</tr></table>"): 
} 
Mcube() 
</script> 


图 秘笈 心 法 


心 法 领悟 204: 浅 谈 variant 变量 。 


本 实例 中 没有 作为 数组 声明 的 variant 也 可 以 表示 数组 。 除 了 长 度 固定 的 字符 串 以 及 用 户 定义 类 型 之 
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variant 变量 可 以 表示 任何 类 型 的 数组 。 尽管 一 个 包含 数组 的 variant 和 一 个 元 素 为 variant 类 型 的 数组 在 概念 上 有 
所 不 同 ， 但 对 数组 元 素 的 访问 方式 是 相同 的 。 


高 级 
趣味 指数 : 机 机 穴 页 


图 实例 说 明 


目前 ， 日 期 型 数据 格式 有 多 种 ， 采 用 录入 方式 相对 来 说 比较 繁琐 ,而且 采用 这 种 方式 也 不 利于 日 期 格式 的 
统一 ， 所 以 可 以 在 信息 录入 页 面 中 加 入 一 个 简单 的 日 期 选择 器 来 解决 上 述 问 题 。 运 行 本 实例 ， 在 新 奥 家 电 连 锁 
后 台 管理 系统 的 销售 查询 页 面 中 ， 单 击 “ 售 货 日 期 ”文本 框 后 的 日 期 选择 图 标 ， 会 弹出 “日 期 选择 器 ”对 话 框 ， 
选择 售 货 日 期 的 起 始 日 期 后 ， 单 击 “ 确 定 ” 按 扭 ， 即 可 成 功 地 将 选择 的 日 期 添加 到 对 应 的 日 期 文本 框 中 ， 运 行 
结果 如 图 3.61 所 示 。 


ye 


车 货 8 期: ” 从” 厅 I0825 到 历 108 瑟 国 到 


当日 基 渤 弄 吕 一 同 页 对 话 要 了 zl 


El Ee 
Ei3 


图 3.61 日 期 选择 器 


图 关键 技术 


由 于 日 期 为 连续 的 数字 , 开发 网 页 时 将 这 些 信息 逐个 写 在 <option> 与 </option> 标 记 之 间 固 然 可 行 , 但 这 会 增 
加 程序 开发 时 间 ， 开 发 本 实例 时 ， 笔 者 将 在 下 拉 列 表 框 中 显示 的 连续 数据 通过 PHP 的 循环 结构 显示 出 来 ， 这 样 
更 灵活 方便 ， 实 现 该 过 程 的 代码 如 下 : 
<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="addday()"></a></div></td> 
<td width="80"> 
<select name="n1"> 
php 
for($i=2005:$i<=2050:SitH){ 
> 


<option value=<?php echo $i;?>><?php echo $i:?></option> 


<?php 
for(Si=1:$i<=12:Sit+Hf 
> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 


} 
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> 
</select> 
月 <htd> 
<td width="77"><select name="r1"> 
<?php 
for(Si=1:Si<=31:SiHH{ 
?> 
<option value=<?php echo $i;:?>><?php echo $i:?></option> 
<?php 
} 
> 
</select> 
日 <htd> 
<td width="16"><div align="center"><a href="#" onClick="subday|)"></a></div></td> 
<t> 
</form> 


图 设计 过 程 
(1) 在 父 窗口 中 创建 函数 open_day_ffom0 和 函数 open_day_to0， 实 现 子 窗口 的 弹出 和 父 窗 口 与 子 窗口 之 


间 的 信息 传递 ， 代 码 如 下 : 
<table width="250" height="25" border="0" align="center" cellpadding="0" cellspacing=" 
<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="adddayO"></a></div></td> 
<td width="80"> 
‘<select name="n1"> 
<?php 
for($i=2005:$i<=2050;$i++) { 
> 


<option value=<?php echo $i;?>><?php echo $i;?></option> 
php 
} 
> 
‘</select> 
年 </td> 
<td width="64"><select name="y1"> 
<?php 
for($i=1:$i<=12:;$iH+) { 
?> 
<option value=<?php echo $i;?>><?php echo $i;?></option> 
<?php 
} 
?> 
‘</select> 
月 <htd> 
<td width="77"><select name="r1"> 
?php 
for($i=1:$i<=31;$it+) { 
?> 
<option value=<?php echo $i;?>><?php echo $i?></option> 
<?php 
} 
> 
</selec> 
日 <td> 
<td width="16"><div align="center"><a href="#" onClick="subday()"></a></div></td> 
</t> 
</form> 
</table> 
<table width="250" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 
<td bgcolor="#826650"><div align="center"><input type="button" onClick="close_ day0" class="buttoncss" value=" 确 定 "></div></td> 
<t> 
</table> 
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(2) 单 击 “确定 ”按钮 ， 调 用 close_day0 函 数 实现 日 期 的 传 值 ， 代 码 如 下 : 
<script language—"javascript"> 
function close_dayO{ 
window.returmnValue=document.form?2.n1.valuet+"-"+document.form?2.yl.valuet+"-"+document.form2.r1.value; 
Window.close0: 


} 
</script> 


图 秘笈 心 法 


心 法 领悟 205: JavaScript 弹出 窗口 。 


实现 窗口 之 问 的 信息 传递 主要 通过 window 的 showModalDialog0 方 法 实现 ， 其 语法 格式 如 下 : 
Window.showModalDialog( 弹 出 窗口 地 址 弹出 窗口 名 称 ,弹出 窗口 所 具有 的 属性 ”) 


窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 栏 、 状 态 栏 、 深 动 条 等 一 些 特性 。 


图 实例 说 明 


为 了 方便 用 户 浏览 网 页 信息 ， 可 以 将 网 页 信息 以 全 屏 显示 的 网 页 模式 展示 给 用 户 ， 这 样 一 来 可 以 方便 用 户 
浏览 到 网 页 的 全 部 信息 ; 二 来 可 以 保证 用 户 查看 后 能 及 时 将 其 关闭 。 运 行 本 实例 ， 在 明日 科技 编程 词典 网 站 中 
单 击 “ 购 买 须知 ” 超 链接 后 ， 将 弹出 如 图 3.62 所 示 的 “购买 须知 ”对 话 框 ， 该 页 面 就 是 通过 全 屏 显示 的 网 页 模 
式 对 话 框 ， 用 户 只 有 关闭 该 页 面 后 ， 才 可 以 查看 网 站 的 其 他 内 容 。 


去 编程 词典 系列 版 本 及 价格 支 
享受 最 务 价格 (元 ) 
| 一 生机 交代 | 
| 每 月 升级 ,每 月 赂 送 最 新 软件 ,编程 锦 讲 ,全 年 提供 30 个 项 目 源 程 序 的 有 限 服务 支持 。 568 
| 每 月 升 绩 ， 每 月 中 渤 东 新 软件 ， 编程 包 赛 。 全 年 提供 50 个 项 目 谣 程 订 的 有 限 服务 支持 。 1998 
| 每 月 升级， 每 月 参 关 是 新 软件 ， 编 程 坟 误 提供 一 年 全 程 技术 支持 服务 。 | one 
享受 服务 | 价格 (元 ) | 
Ee 128 | 
| 每 月 升级 ， 每 月 昭 过 是 新 软件 ， 护 程 坟 训 全 年 提供 30 个 项 目 源 程 序 的 有 限 服务 支持 。 se8 
| 每 月 天， 每 月 踪 及 新 软件 ， 编程 包 喜 、 全 年 提供 s0 个 项 目 源 程 序 的 有 限 服务 支持 。 | 1998 | 
| 每 月 升级 ， 每 月 昭 送 是 新 软件 ， 扩 程 哥 。 提 供 一 年 全 程 技术 支持 服务 - | 


图 3.62 弹出 全 屏 显 示 的 网 页 模式 对 话 框 


图 关键 技术 


本 实例 主要 应 用 screen 对 象 的 width 、height 属性 和 window 对 象 的 showModalDialog0 方 法 实现 ， 
showModalDialog( 方 法 用 于 弹出 全 屏 显示 的 网 页 模式 对 话 框 ， 其 语法 格式 如 下 : 

variant = object.showModalDialog(sURL [. vArguments [, sFeatures]]) 

参数 说 明 : 

sURL: 指定 URL 文件 地 址 。 

VArguments: 用 于 向 网 页 对 话 框 传递 参数 。 传 递 参数 的 类 型 不 受 限 制 ， 对 于 字符 串 类 型 ， 最 大 为 4096 个 字 
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符 ， 但 也 可 以 传递 对 象 ， 例 如 index.html。 
图 设计 过 程 
(1) 创建 提供 “购买 须知 ” 超 链接 的 页 面 ， 在 该 页 面 中 添加 空 的 超 链接 ， 在 该 超 链接 的 onClick 事件 中 调 
用 自 定义 Es 函数 opendialog0)， 代码 如 下 : 
(2) 编写 自 定义 JavaScript 函数 opendialog0， 用 于 打开 全 屏 显示 的 网 页 对 话 框 ， 代 码 如 下 : 
和 


ight; 
window.showModalDialog("notice.php",""."dialog Width="+width+"px:dialogHeight="+height+"px:status-no:help=no:scrollbars=no”) 
. 
</script> 


图 秘笈 心 法 


心 法 领悟 206: showModalDialog0) 与 showModelessDialog0 的 区 别 是 什么 ? 
二 者 的 区 别 在 于 showModalDialog0 打 开 的 网 页 对 话 框 为 模式 窗口 ， 置 在 父 窗 口上 ， 必 须 关 闭 才 能 访问 父 窗 
口 ; 而 showModelessDialogO 打 开 的 对 话 框 是 无 模式 窗口 ， 打 开 后 不 必 关 闭 也 可 以 访问 父 窗口 或 其 他 窗口 。 


力 实例 说 明 


通常 情况 下 ， 当 使 用 JavaScript 的 window.closeO 语 句 关闭 正 主 窗口 时 , 会 弹出 一 个 “您 查看 的 网 页 正在 试 
图 关闭 窗口 。 是 否 关 闭 此 窗口 ? ”的 询问 对 话 框 。 在 制作 网 络 应 用 程序 时 ， 这 种 情况 是 用 户 不 想 看 到 的 ， 那 么 
如 何 才能 屏蔽 该 对 话 框 呢 ? 本 实例 将 介绍 解决 该 问题 的 方法 。 和 运行 本 实例 ， 如 图 3.63 所 示 ， 单 击 “关闭 窗口 ” 
超 链 接 后 ， 该 下 窗口 将 被 直接 关闭 。 


Q 编 释 闻 典 
和) 避 玫 用 本 全 提 代 了 生生。 于 者 可 以下 开价 项 目 源码 、 婚 闪 技 和 
全 十 要 胡 数 下 区 际 开 发 的 所 用 。 忆 组 科 水 


有 
来 涛 于 公 in, 还 有 的 来 自 活 者 的 问题 A 


长。 
六 并 名 和 有 妥 芝 给 关 和 和 着 提亲 下 用 扩 直 。 《ph 近 和 词 )》 软件 开 发 人 以 上 
和 


+ EO 


3.63 关闭 窗口 不 弹出 对 话 框 


图 关键 技术 


本 实例 主要 应 用 window 对 象 的 opener 属性 将 要 关闭 的 正 窗口 的 打开 窗口 设置 为 null, 然后 再 通过 window 
对 象 的 close0 方 法 将 该 窗口 关闭 ， 这 样 就 不 会 弹出 询问 对 话 框 。 


图 设计 过 程 
创建 index.php 文件 ， 添 加 一 个 用 于 关闭 窗口 的 超 链接 ， 在 该 超 链接 的 onClick 事件 中 添加 控制 窗口 关闭 的 
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代码 ， 如 下 所 示 : 
<a href="#" onClick="window.opener=null:window.close0:"> 。 关闭 窗口 <a> 


图 秘笈 心 法 


心 法 领悟 207: 详解 opener。 

opener 是 一 个 可 读 可 写 的 属性 ， 对 一 个 window 对 象 返回 一 个 引用 ， 用 于 指定 打开 本 窗口 的 窗口 对 象 ， 语 
法 格式 如 下 : 

window.opener 

window.opener 方 法 

window.opener. 属 性 

opener 属性 返回 的 是 一 个 窗口 对 象 ， 其 与 打开 该 窗口 的 父 窗口 相 联系 ， 当 访问 子 窗口 的 opener 属性 时 ， 返 
回 的 是 父 窗口 。 通 过 该 属性 ， 可 以 使 用 父 窗口 对 象 中 的 方法 和 属性 。 


实例 208 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 需 要 考虑 网 站 的 安全 性 ， 例 如 ， 设 置 允许 哪些 用 户 访问 是 一 项 非常 重要 的 技术 。 本 实 
例 在 页 面 中 设置 一 个 访问 权限 ， 判 断 用 户 是 否 可 以 访问 该 网 页 。 如 果 用 户 名 和 密码 不 正确 就 不 可 以 访问 ， 并 弹 
出 提示 对 话 框 重 定向 到 该 网 页 ， 运 行 结果 如 图 3.64 所 示 。 


留言 内 容 : 


ml Ey 


3.64 ”弹出 提示 对 话 框 并 重 定向 网 页 


国 关键 技术 


本 实例 主要 将 PHP 与 JavaScript 相 结合 , 通过 JavaScript 脚 本 来 弹出 对 话 框 信息 , 应 用 window 对 象 中 的 alert0 


方法 和 窗口 属性 location 实现 此 功能 ， 语 法 格式 如 下 : 
alert (弹出 对 话 框 的 内 容 ?: 
window location hre 人 -重新 定向 的 页 面 " 
参数 说 明 : 
alert0: 弹出 一 个 警告 对 话 框 。 


PHP 开发 实战 1200 例 (第 I 卷 ) 
location: 定位 区 ， 也 叫 地 址 栏 ， 是 可 以 输入 URL 的 浏览 器 文本 区 。 


图 设计 过 程 


a 向 网 页 文件 的 关键 代码 如 下 : 


<?php session_start(); 
<title> 弹 家 抽 示 对 说 要 并 重 定向 网 页 </title> 


这 $gly 一 true && Smima—true){ 
这 sljid 一 true){ 
S$ljid=-$ GET[1liid]; 
echo "这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 !":} 
> 
<?php }else{ 
echo "<script>alert (这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 "); window.location.href='admin.php';</script>"; 
} 
> 


图 秘笈 心 法 


心 法 领悟 208: 浅 谈 网 页 重 定 向 。 
这 里 的 网 页 重 定向 与 PHP 判断 用 户 登录 权限 页 相似 ， 都 是 网 页 的 一 种 跳 转 方法 。 


趣味 指数 : 人 请 窗 催 商 


图 实例 说 明 

进入 网 站 后 ， 很 多 网 站 都 会 弹出 一 个 新 窗口 (如 广告 等 ) ， 多 数 窗口 需要 浏览 者 自行 关闭 。 为 了 方便 浏览 
者 对 页 面 中 信息 的 浏览 ， 本 实例 运用 一 种 新 的 方法 来 解决 弹出 窗口 关闭 这 一 问题 。 当 浏览 者 进入 某 网 站 进行 浏览 
时 ， 无 需 关 闭 弹出 的 新 窗口 ， 在 页 面 运行 超过 一 定 的 时 间 之 后 ， 该 窗口 将 自动 关闭 ， 这 将 大 大 方便 浏览 者 的 浏 
览 。 运行 本 实例 , 将 弹出 一 个 新 窗口 显示 广告 信息 ， 如 图 3.65 所 示 ， 该 广告 窗口 在 页 面 运行 5 秒 钟 后 自动 关闭 。 


图 3.65 ”自动 关闭 的 广告 窗口 


图 关键 技术 

本 实例 主要 应 用 window 对 象 的 setTimeout0 方 法 ， 实 现 延迟 执行 某 一 操作 。window 对 和 象 的 setTimeout0 方 
法 的 语法 格式 如 下 : 

setTimeout(expression.secdelay[.language]) 
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参数 说 明 : 
expression: 是 一 个 字符 串 ， 可 包含 任何 对 函数 、 方 法 或 者 单个 JavaScript 语句 的 调用 。 
secdelay: 指定 运行 间隔 的 时 间 ， 以 毫秒 为 单位 。 
language: 指定 语句 或 参数 expression 调用 的 函数 所 使 用 的 脚本 语言 。 如 果 完 全 使 用 JavaScript， 则 不 需 设 
置 该 参数 。 
图 设计 过 程 
(1) 通过 JavaScript 脚本 实现 打开 新 窗口 功能 ， 代 码 如 下 : 
<script language="javascript"> 
window.open("new.htm","new","height=135.width=180.top=10.left=20"); 
</script> 
(2) 通过 设置 window 对 和 象 的 setTimeout0 方 法 ， 实 现 弹出 新 窗口 的 自动 关闭 ， 代 码 如 下 : 
<body onLoad="window.setTimeout(window.closeO.5000)"> 
图 秘笈 心 法 
心 法 领悟 209: 秒 与 毫秒 。 
如 果 用 户 不 是 运动 员 ， 很 少 能 接触 到 毫秒 这 个 单位 。 但 是 在 计算 机 领域 中 ， 毫 秒 是 经 常 被 用 到 的 。 秒 与 毫 
秒 的 换算 比例 是 1:1000， 也 就 是 说 1 秒 等 于 1000 毫秒 。 


实例 210 


趣味 指数 : 会 傅 依从 | 


实例 说 明 


在 论坛 、 博 客 等 注册 页 面 添加 头像 选择 功能 ， 可 以 增加 网 页 活力 。 运 行 本 实例 ， 首 先 单 击 图 3.66 中 的 “ 头 
像 选择 ” 超 链接 ， 在 弹出 的 窗口 中 选择 自己 喜爱 的 头像 后 ， 弹 出 窗口 将 自动 关闭 ， 注 册页 面 中 的 头像 变 成 用 户 
所 选择 的 头像 。 


ail: + 请 铀 入 真实 的 E-asil 地 址 


PE 司 ， 
头 重 : 仿 
和 


ET 全 郑重 写 


图 3.66 选择 头像 


图 关键 技术 


本 实例 通过 调用 window 对 象 的 showModalDialog( 方 法 弹出 一 个 窗口 ， 当 用 户 单 击 某 个 头像 后 ， 将 该 头像 
对 应 的 数值 传递 给 父 窗 口 ， 父 窗口 通过 传递 过 来 的 数值 指定 用 户 所 选择 的 头像 。 
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设计 过 程 
(1) 首先 在 窗口 中 添加 “头像 选择 ” 超 链 接 ， 以 便 调用 select_face0 函 数 实现 窗口 的 弹出 功能 ， 代 码 如 下 : 


[<a href="#" onclick="select_face0O" class="a1"> 头 像 选择 </a>] 
(2) 利用 Javascript 编写 select_face0 函 数 , 实现 头像 选择 窗口 的 弹出 以 及 返回 用 户 所 选择 头像 对 应 的 数值 ， 


代码 如 下 : 
<script language—"javascript"> 
function select_faceO{ 
Var somevalue; 
somevalue=window.showModalDialog("browse.php"," 请 选择 您 喜欢 的 人 物 头像 " "dialogWidth='310px':dialogHeight='240px':status='no';help='no'; 
Scrollbars=no'"); 
document,form_registuser_src.src="images/head/"+somevaluet" .gif 
} 
< 


(3) 在 弹出 的 窗口 中 通过 selectfaceO 函 数 返回 用 户 所 选择 头像 对 应 的 数值 ， 代 码 如 下 : 
<script language="javascript"> 
finction selectface(ICQ){ 


图 秘笈 心 法 


心 法 领悟 210: showModalDialog() 方 法 详解 。 
Window.showModalDialog( 弹 出 窗口 地 址 ' "弹出 窗口 名 称 ' 弹出 窗口 所 具有 的 属性 7 
窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 


高 级 


实例 211 人 


国 实例 说 明 
网 络 不 仅 是 信息 的 海洋 ， 也 是 广告 的 海洋 。 除 了 普通 的 gf 和 flash 之 外 ， 浮 动 广告 也 是 时 下 网 上 较为 流行 
的 广告 形式 之 一 ， 当 拖 电 浏览 器 的 滚动 条 时 ， 这 种 页 面 上 浮动 的 广告 ， 可 以 跟随 屏幕 一 起 移动 ， 这 种 效果 对 于 
广告 展示 有 相当 大 的 实用 价值 。 本 实例 将 制作 一 个 浮动 的 广告 窗口 ， 运 行 结果 如 图 3.67 所 示 。 
和 | 
i 


口 图 书 调查 显示 结果 


1 您 经 常 购 科 的 纺 程 类 图 书 尾 于 哪 一 类 ? 

[2 
局 ab 
在 贱 天 助 | 你 使 用 下 面世 种 编程 开 言 或 工具 ? 


开发 手册 厂 百 例 三 技巧 “三 实例 入 绩 三 教程 


Tw Cw Tw Ti Tre Ti TXE 
3、 你 景 原意 购买 或 并 闻 时兴 图 书 ? 
厂 入 门类 图 上 。 厂 讲解 实例 。 厂 元 全 实例 “三 百 例 型 三 技巧 型 


提交 


图 3.67 浮动 的 广告 窗口 
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图 关键 技术 


本 实例 主要 应 用 DIV 层 制作 浮动 广告 , 然后 应 用 document.write0 方 法 输出 DIV 层 。document write() 方 法 的 
语法 格式 如 下 : 

document. write(value,...) 

参数 说 明 : 

value: 要 添加 到 document 的 任意 一 个 Javascript 值 。 如 果 该 值 不 是 字符 串 ， 那 么 在 被 添加 文档 之 前 ， 会 被 
转化 成 一 个 字符 串 。 

…: 任意 多 个 0 个 或 多 个 ) 要 (依次 ) 写 入 文档 的 值 。 


图 设计 过 程 


(1) 在 网 站 首页 引入 JavaScript 脚本 文件 ， 代 码 如 下 : 
<SCRIPT language=JavaScript src="jsleftjs"></SCRIPT> 
(2) 运用 JavaScript 脚本 自 定义 函数 控制 浮动 广告 的 位 置 及 其 相关 属性 ， 代 码 如 下 : 
Var adve=0.15 
Var collection; 
function motion0 { 
this.items= []; 
this.addItem= function(id,x,y,content){ 
document.write('<DIV id="+id+’ style="Z-INDEX: 10; POSITION: absolute; width:80px; 
height:60px:left:'+(typeof(x)=='string'’?eval(x):x)+";top:"+(typeof(y)=='string'?eval(y):y)+">"+content+"</DIV>"); 
var newltem= {}; 
newlItem.object= document.getElementById(id); 
newltem.x= Xx; 
newltem.y=y; 
this.items[this.items.length]= newItem: 


} 
this.play=function(){ 
collection=this.items 
setInterval(‘playO',10); 

} 


} 

functionplay0 { 

for(var i=0;i<collection.length;it+) { 

Var followOb= collection[i].object; 

varfollowObj x =(typeoftcollection[i].x)=='string’?eval(collection[i].x):collection[i].x): 
var followObi y= (typeoftcollection[il.y)=='string'?eval(collection[il.y):collection[il.y): 
if(followObj.offsetLeft!=(document.body.scrollLeft+followObj_x)) { 

Var dx=(document.body.scrollLeft+followObj_x-followObj.offsetLeft)*adve: 
dx=(dx>0?1:-1)*Math.ceil(Math.abs(dx)): 

followObi.style.left-followObj.offsetLeft+dx: 


} 

if(followObi.offsetTop!=(document.body.scrollTop+followObj y)) { 

var dy=(document.body.scrollTop+followObj_y-followObj.offsetTop)*adve: 
dy=(dy>07?1:-1)*Math.ceil(Math.abs(dy)): 
followObi.style.top=followObi.offsetToptdy: 

} 

followObj.style.display = ="; 

} 

} 

var themotion= new motion0: 

themotion.addItem('followDiv1',200,200,'<a href="http://wpa.qq.com/msgrd?V=1&Uin=228691050&Site= 在 线 咨询 &Menu=no" title=" 在 线 即时 交谈 
"><img ste=./images/qqhelp.gif -height=70 width="80" border=0></a>"); 
themotion.playO: 


图 秘笈 心 法 

心 法 领悟 211: 使 用 document.write0 方 法 的 注意 事项 。 

调用 方法 document.write0 的 结果 也 许 不 能 立刻 在 目标 浏览 器 窗口 中 显示 出 来 ， 这 是 因为 浏览 器 可 能 会 将 数 
据 缓 存 起 来 ， 以 便 形成 大 的 数据 块 输出 。 
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NE a i ey OR i i | 
实例 212 浙 ee Ey 
[2 ood 
国 实例 说 明 
告 作为 网 站 最 大 的 盈利 手段 ， 任 何 网 站 都 不 可 能 将 其 省 略 ， 那 么 ， 如 何 才能 实现 网 站 既 可 以 从 广告 中 获 


利 ， 又 能 使 用 户 流畅 地 阅读 网 站 信息 呢 ? 本 实例 将 介绍 如 何 制作 一 个 从 首页 右 下 角 弹 出 的 渐 显 广告 窗 体 ， 该 窗 
体 在 用 户 登 录 网 站 时 自动 从 右 下 角 渐 渐 弹 出 ， 然 后 由 用 户 手动 关闭 。 本 实例 的 运行 结果 如 图 3.68 所 示 。 


名 BB$ | 息 Bi 已 x 于。 六 mx3 和 go FR 


必 _ 编 程 者 之 家 


我 有 6 用 多才 )4978981 4976% 1 : 。 而 ronl Basic 护 得 河和 TiNi 本 各 河 由 “交加 启用 


图 3.68 右 下 角 渐 显 广告 


力 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 ，window 对 象 主要 用 于 在 HTML 中 打开 窗口 ， 应 用 极为 普 
遍 ,但 也 有 一 些 缺 陷 。 用户 浏览 器 决定 窗口 的 外 观 ， 设计 者 左右 不 了 其 窗口 的 大 小 及 样式 , 但 JavaScript 给 了 程 
序 这 种 控制 权 。 在 JavaScript 中 ， 可 以 使 用 window 对 象 来 实现 对 窗口 的 控制 。 


图 设计 过 程 
本 实例 主要 应 用 window 对 象 的 open0 方 法 打开 一 个 在 首页 右 下 角 弹 出 渐 显 的 广告 窗口 , 在 网 站 首页 中 添加 
如 下 代码 : 


<scriptlanguage="javascript"> 
var newformW=300; 


ee ""width="+newformW+".height="+newformH+",top="+T+".left="+L): 
3 

PPpO; 

</script> 


力 秘笈 心 法 


心 法 领悟 212: window 对 和 象 打开 窗口 详解 。 
使 用 window 对 象 打开 窗口 的 语法 格式 如 下 : 


windowVar=window.open(url.windowname[.location]): 
参数 说 明 : 
windowVar: 当前 打开 窗口 的 句柄 。 如 果 open0 方 法 成 功 ， 则 windowVar 的 值 为 一 个 window 对 和 象 的 句柄 ， 
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否则 windowVar 的 值 是 一 个 空 值 。 

url: 目标 窗口 的 URL。 如 果 URL 是 一 个 空 字符 串 ， 则 浏览 器 将 打开 一 个 空白 窗口 ， 允 许 用 write0 方 法 创 
建 动 态 HTML。 

windowname: window 对 象 的 名 称 。 

location: 对 窗口 属性 进行 设置 。 


3.7 ”状态 栏 设计 
不 论 是 在 应 用 程序 中 还 是 在 网 页 中 都 会 应 用 到 状态 栏 ， 状 态 栏 可 为 用 户 提供 一 些 提示 信息 ， 如 当前 系统 的 


日 期 和 时 间 、 软 件 版 本 、 链 接地 址 、 系 统 信 息 以 及 一 些 自 定义 信息 等 。 


实例 213 


图 实例 说 明 

浏览 网 页 时 ， 用 户 往 往 更 加 注意 网 站 页 面 的 内 容 ， 而 不 会 过 多 注意 状态 栏 ， 如 果 为 页 面 的 状态 栏 添加 一 
些 特效 ， 一 定 会 给 网 站 增添 一 道 亮 丽 的 风景 。 本 实例 实现 在 状态 栏 中 显示 跑马 灯 特 效 文字 ， 运 行 结果 如 图 3.69 
所 示 。 


文件 四 ”三 得 下 ) 查看 W) 收 站 这 工具 I) 帮助 _ 
起 址 四川 。 htte: 192 168 1 59/wr/03/213 


本 ENH | 意见 
> 多 和 当前 位 置 : 公司 首页 》 图 1 绍 》J5E 


新书 


5 2007 新 书 推介 
Es rn a 


肥 将 上 市. 区 请 


图 3.69 跑马 灯 文字 


力 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 的 status 属性 ， 并 通过 编写 自 定义 函数 来 设置 状态 栏 中 的 文 
字 及 文字 属性 ， 通 过 站..else 条 件 语句 来 控制 文字 的 循环 显示 效果 。 
最 后 ， 在 <body> 标 记 中 调用 该 函数 ， 从 而 实现 状态 栏 中 的 跑马 灯 文 字 特效 。 


图 设计 过 程 


llit(s 
var text=” ”您 好 ! 欢迎 访问 明日 科技 图 书 网 站 。 客 服 热线 : 0431-84978981" 
var printtext =" "; 

vari=1; 

f(s>210){ 
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} 
else f(s<=210 &é s> 0){ 
for (i=0;i<s:iHH){ 


了 

elseif (s <=0){ 

f(s < textlength){ 

i ‘substring(-s,text.length); 


人 SetTimeout("scrollit(100)",200); 


} 
</SCRIPT> 


(2) 在 <body> 标 记 中 调用 自 定义 的 函数 。 
<body onLoad="scrollit(100):"> 


图 秘笈 心 法 


心 法 领悟 213: window 对 象 的 status 属性 详解 。 
window 对 象 的 status 属性 的 语法 格式 如 下 : 


window.status 
属性 status 是 一 个 可 读 可 写 的 字符 串 ， 声 明 浏览 器 状态 栏 的 当前 内 容 


图 实例 说 明 


中 。 运 


为 了 在 节省 网 页 空间 的 同时 更 好 地 服务 于 广大 的 用 户 ， 可 以 将 网 站 要 显示 的 简短 的 广告 信息 显示 在 状态 栏 
行 本 实例 ， 在 状态 栏 中 收缩 显示 明日 科技 公司 的 网 址 和 客服 热线 ， 运 行 结果 如 图 3.70 所 示 。 


当 在 状 坟 栏 中 收 管 显示 文字 - Wi eroroft Tnternst Erplen ll 
文件 四 畸 往 四 查看 员 ) ET A 帮 荔 中 


BE hetp /192 158 1 sajnr/0s/214 了 | om 


二 


; 4 > 
次 区 本 坟 梧 本目 科技 主页 ;we ningri (客服 扑 线 ; 0431-54376561) | | ”| ”|@ 可 篇 站 点 加 


3.70 ”收缩 显示 文字 


第 3 章 Web 页 面 交互 


力 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 当 显 示 的 文字 总 长 度 等 于 该 文本 的 长 度 时 , 再 反方 向 滚动 文字 ， 
从 而 实现 在 状态 栏 中 收缩 显示 文字 。 

window 对 象 的 status 属性 的 语法 格式 如 下 : 

window.status 


属性 status 是 一 个 可 读 可 写 的 字符 串 ， 声 明了 浏览 器 状态 栏 的 当前 内 容 。 
图 设计 过 程 
本 实例 主要 通过 JavaScript 脚本 编写 状态 栏 中 收缩 显示 文字 特效 的 自 定义 函数 ， 完 整 代 码 如 下 : 


<Script language=JavaScript> 
var text1=" 欢迎 访问 明 日 科技 主页 : www.mingrisoft.com"; 


} 

else {cometott;if(cometo—textl.length) {comeback=1}} 
window.status=text1.substring(0,cometo)+"( 客 服 热 线 : 0431-84978981)"; 
if(cometo—textl .length){window.setTimeout("dis()",1000)} 

else {window.setTimeout("disO".50)} 

} 

dis0; 

</script> 


图 秘笈 心 法 


心 法 领悟 214: 状态 栏 。 
状态 栏 其 实 只 是 起 到 一 个 类 似 于 广告 的 作用 ， 只 


实例 说 明 


在 状态 栏 中 显示 数字 时 钟 是 个 性 化 网 站 所 特有 的 功能 ， 它 不 仅 可 以 节约 网 页 空间 ， 而 且 可 以 方便 用 户 时 时 
查看 。 本 实例 实现 在 状态 栏 中 显示 一 个 24 小 时 制 的 数字 时 钟 ， 运 行 结果 如 图 3.71 所 示 。 


rosoft Internet Erplerer 


文件 加 ”强加 E) 查看 中 收 豪 WW) 工具 IT) 帮助 00 正 了 
下 如 vt//192 lca 1 sayaryoyzts EE 
已 | 

是 a | © 
- | 
rs 三 三 到 


图 3.71 状态 栏 显示 时 钟 


Zl 
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图 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 实现 在 状态 栏 中 显示 数字 时 钟 ， 具 体 详细 讲解 请 参考 实例 214。 


图 设计 过 程 


(1) 本 实例 主要 通过 JavaScript 脚本 开发 状态 栏 中 显示 动态 数字 时 钟 的 自 定义 函数 ， 代 码 如 下 : 
<script language="JavaScript"> 

var timerID = null; 

var timerRunning = false; 


function stopclock O{ 
clearTimeout(timerID); 
timerRunning = false; 

} 


function showtime O { 
Var now = new Date(): 
Var hours = now.getHours(); 
Var minutes = now.getMinutes(); 
Var seconds = now.getSeconds() 
var timeValue = "北京 时 间 : "+ ((hours >24) ? hours -24 :hours) 
timeValue += ((minutes < 10) ? ":0" : ":") + minutes 
timeValue += ((seconds < 10) )+seconds 
window. status = timeValue; 
timerID = setTimeout("showtime()",1000); 
timerRunning = tme: 
} 
function startclock O { 
stopclock():; 
showtime(); 
</script> 
(2) 在 <body> 标 记 中 调用 自 定义 函数 startclock0， 代 码 如 下 : 
<body onLoad="startclockO"> 


力 秘笈 心 法 


心 法 领悟 215: JavaScript 脚本 中 时 间 的 设置 。 
在 JavaScript 脚本 中 设置 日 期 和 时 间 ， 首 先 要 实例 化 Date 类 ， 然 后 调用 其 中 的 方法 ， 获 取 对 应 的 日 期 、 时 


间 值 。 


容 。 


3.8 导航 菜单 设计 


网 站 导航 菜单 对 于 每 个 网 站 都 是 必 不 可 少 的 ， 它 相当 于 城市 中 的 路 标 ， 可 以 指引 浏览 者 找到 自己 热衷 的 内 
导航 菜单 有 很 多 种 ， 如 本 节 中 介绍 的 带 图 标的 文字 导航 条 、flash 导航 条 、 按 钮 导航 条 、 弹 出 式 下 拉 菜 单 、 


二 级 导航 菜单 、 树 状 菜单 等 。 
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趣味 指数 : 会 全 二 例 : 


力 实例 说 明 
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树 形 结构 能 够 以 层次 形式 展示 信息 ， 用 它 来 描述 具有 上 下 级 关系 的 内 容 再 恰当 不 过 。 本 实例 利用 菜单 的 树 
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形 结构 来 描述 企业 的 人 事 组 织 架 构 ， 效 果 如 图 3.72 所 示 。 
ER 


罗 程序 开发 部 门 


a2 


@h 


加 加 


电容 户 服 务 部 门 


3.72 ” 树 形 导航 菜单 


键 技术 


本 实例 中 实现 菜单 的 树 形 显示 是 通过 <table> 标 签 结合 DIV 实现 的 。 父 节点 利用 表格 来 显示 ， 


子 节点 利用 


DIV 顽 套 表格 来 实现 。 这 样 做 的 目的 是 容易 对 子 节点 的 显示 和 隐藏 进行 控制 。 例 如 ， 当 用 户 单 击 父 节点 时 ， 如 
果子 节点 没有 展开 ,将 DIV 设置 为 可 见 就 可 以 显示 子 节点 ; 如 果子 节点 可 见 , 将 DIV 设置 为 不 可 见 就 可 以 隐藏 


子 节点 。 
图 设计 过 程 


(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ， 在 表格 的 第 2 行 再 添加 一 个 2 行 2 列 的 表格 。 表 


格 的 第 1 列 用 于 显示 节点 前 的 图 标 ， 第 2 列 描述 节点 文本 ， 主 要 代码 如 下 : 
<form id="forml" name="forml" method="post" action="" > 
<table width="372" border="1" align="center"” bgcolor="#E6F2F2" bordercolor="#478D8D" 


style="border-style:none" cellspacing="0" > 
<t> 
<td scope="col" align="center" style="border-bottom-style:none" > 人 事 组 织 架 构 </td> 
</t> 
<tr> 
<td> 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left"> 
<2php /导入 PHP 脚本 
Sxml file = simplexml load file("org.xml"); /1/ 从 XML 文件 中 加 载 节点 
foreach($xml_file->children() as $node){ /遍历 根 节点 
?> 
<t> 
<td width="38%" align="right"> /设置 节点 图 标 
<img src="images/rootnode .gif' width="15" height="15" border="0" > </img> 
<ltd> 
<td width="62%" left="0px" align="left" ><a href="#" onclick= "ShowNode(<?php echo Snode ?>)">&nbsp:&nbsp: 
<?php echo $node ?></a> /设置 节点 文本 
<ltd> 
<t> 
<t> 
<td width ="38%" align="center” > 
</td> 


<td width="62%" > 
<div id= <?php echo Snode ?> style = "display:none" class="HideDiv" > /定义 DIV 
<table width="10096" border="0" cellpadding="0" cellspacing="0" align="left" > 
<?php 
foreach($node->children() as $value){ // 妨 历 子 节点 
?> 
<tr> 
<td width ="10%" align="right" > 
<img ste="images/childnode.gif" width="15" height="15" border="0" > </img> 

<htd> 


<td width="90%" align="left” ><a href-"#" >&nbsp:&nbsp;<?php echo $value?></a> 


<ftd> 
</tr> 
<aphp 
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language="javascript"> 
function ShowNode(ParentID) { /隐藏 或 显示 子 节点 
varDiv= ParentID; 
if (Div.style.display 一 "none"){ 
Div.style.display = "block"; // 显 示 DIV， 以 此 来 显示 子 节点 
Yelse if (Div.style.display 一 "block"){ 
Div.style.display = "none"; /隐藏 DIV， 间 接 隐 藏 子 节点 
上 
} 
</script> 
</form> 
(3) 人 事 组 织 的 架构 存储 于 XML 文件 org.xml 中 。 


图 秘笈 心 法 


心 法 领悟 216: 动态 设置 超 链接 。 
在 设计 网 站 项 目 时 ， 有 时 需要 根据 实际 情况 动态 设置 超 链接 的 内 容 。 在 利用 标签 <a> 定 义 超 链接 时 可 以 结合 
PHP 脚本 来 实现 这 一 功能 ， 例 如 : 


<a href="#" onclick= "ShowNode(<?php echo Snode ?>)">&enbsp;éenbsp; <?php echo Snode ?></a> 


| 
Ne hk " 


力 实例 说 明 


在 网 站 中 不 仅 可 以 设置 导航 条 ， 而 且 还 可 以 设置 导航 菜单 。 由 于 菜单 内 容 比 较 多 ， 在 同一 页 面 中 显示 会 
较 杂乱 ， 所 以 目前 大 多 设计 者 都 采用 收缩 式 的 导航 菜单 。 运 行 本 实例 ， 当 浏览 者 单 击 “ 网 站 管理 ” 
在 其 下 方 将 弹出 导航 菜单 ， 如 图 3.73 所 示 ， 浏 览 者 再 次 单 击 “ 网 站 管理 ” 超 链接 时 ， 导 航 菜单 又 收缩 回去 ， 页 
面 中 不 再 显示 菜单 中 的 内 容 。 


Ro 
CE 
后 台 管理 首页 /退出 (< 


同 站 管理 Q 
初始 化 信息 
服务 器 信息 


3.73 ”收缩 式 菜单 


图 关键 技术 


本 实例 主要 是 利用 显示 、 隐 藏 表格 来 实现 收缩 式 导航 菜单 的 功能 。 单 击 导航 超 链接 ， 显 示 当 前 菜单 的 内 容 ， 
隐藏 上 一 个 显示 的 菜单 。 在 隐藏 菜单 时 ， 让 其 有 规律 地 隐藏 进而 实现 动画 效果 。 
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力 设计 过 程 


(1) 显示 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascripf> 
function show(obj,maxg,obj2){ 
这 cbj.style pixelHeight<maxg) { 
obj.style.pixelHeight+=maxg/10: 
‘obij .filters.alpha.opacity+=20: 
obi2.backeround="images/title hide.gif"; 
if(obj.style.pixelHeight—maxg/10) 
obj.style.display="block'; 
myObj=obij; 
mymaxg=maxg; 
myObj2=0bj2; 
setTimeout('show(myObi,mymaxg,myObi2),5); 
} 
} 
</SCRIPT> 
(2) 隐藏 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function hide(obj,maxg,obj2){ 
这 obj.style.pixelHeight>0) { 
ifobij.style.pixelHeight 一 maxg/S) 
obj.style.display='none’; 
obj.style.pixelHeight-=maxg/5; 
‘obi.filters.alpha.opacity-=10; 
obj2.background="images/title_show.gif"; 
myObj=obj; 
mymaxg=maxg 
myObj2=obj2; 
setTimeout(hide(myObj.mymaxg.myObj2) 5); 


else 
这 whichContinue) 
whichContinue.click(); 
} 
</SCRIPT> 


(3) 单 击 菜单 上 的 文字 超 链接 时 ， 隐 藏 前 一 个 菜单 ， 显 示 当 前 菜单 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function chang(obj,maxg,obj2){ 

if(obj.style.pixelHeight) { 
hide(obj.maxg.obj2): 
nopen="; 
whichcontinue="; 
3 
else 
这 nopen){ 
whichContinue=obij2; 
， mopen.clickO: 
elsef 
show(obj.maxg.obj2); 
nopen=obj2: 


</SCRIPT> 

(4) 在 表格 的 相关 鼠标 事件 中 调用 自 定义 的 方法 和 属性 来 改变 收缩 菜单 的 显示 和 隐藏 ， 代 码 如 下 : 
<TD class=list_title id=listl onmouseover="this.typename='list title2:” onclick=chang(menu1,60,listl): onmouseout="this.typename='list_title:" 
background="images/title_hide.gif” height=25><SPAN> 网 站 管理 </SPAN> </TD> 


秘笈 心 法 
心 法 领悟 217， 收缩 式 导航 菜单 。 
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收缩 式 导航 菜单 是 笔者 最 喜欢 的 导航 菜单 ,虽然 只 是 由 一 些 JavaScript 事件 组 成 , 但 是 操作 时 的 动态 效果 
很 强 。 


图 实例 说 明 

对 于 一 个 企业 网 站 来 说 ，“ 联 系 我 们 ” 超 链接 是 必 不 可 少 的 。 为 了 更 加 引 人 注 意 ， 可 以 将 其 制作 成 具有 展 
开 式 动画 效果 的 导航 条 。 运 行 本 实例 ， 可 以 看 到 页 面 右 侧 的 “联系 我 们 ”导航 条 是 逐渐 展开 的 ， 并 且 每 次 刷新 
页 面 时 ， 都 会 以 同样 的 动画 效果 展开 ， 展 开 效 果 如 图 3.74 所 示 。 


图 3.74 展开 式 导 航 条 
图 关键 技术 
本 实例 主要 是 通过 自 定义 JavaScript 函数 控制 图 片 〈image) 对象 的 height 属性 值 实现 的 。 为 了 实现 动画 效 
果 ， 在 JavaScript 函数 中 还 需要 应 用 setTimeout0 方 法 延迟 执行 改变 图 片 高 度 的 操作 。 


图 设计 过 程 


(1) 在 网 页 中 显示 “联系 我 们 ”导航 条 的 位 置 插入 一 张 全 部 展开 后 的 “联系 我 们 ”导航 图 片 ， 在 需要 设置 
超 链 接 的 文字 上 添加 图 片 热点 并 设置 相应 的 超 链接 。 

(2) 将 图 片 的 height 属性 值 设置 为 0，name 属性 设置 为 our。 

(3) 编写 自 定义 的 JavaScript 函数 ourmove0， 用 于 实现 图 片 的 展开 效果 。ourmove0 函 数 的 代码 如 下 : 


our.height=our height+3 
setTimeout(ourmove.1) 
> 
(4) 在 当前 页 面 的 最 底部 ， 也 就 是 </body> 标 记 之 前 ， 添 加 如 下 代码 实现 导航 条 的 展开 式 动画 效果 。 
<script language="javascript"> 
‘ourmove(): 
</scrip> 


力 秘笈 心 法 


心 法 领悟 218: 使 用 ourmove0O 函 数 的 注意 事项 。 
- 定 要 将 调用 ourmove0 函 数 的 代码 放 在 </body> 标 记 之 前 ， 否 则 页 面 的 其 他 内 容 就 要 等 到 动画 显示 完毕 才 
可 以 显示 ， 达 不 到 预期 的 效果 。 
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高 级 


i 
实例 219 ee Se 


图 实例 说 明 


在 设计 网 站 的 导航 菜单 时 ， 有 时 为 了 让 用 户 快速 了 解 菜 单 导航 的 详细 内 容 ， 需 要 为 菜单 设置 提示 信息 。 这 
样 当 用 户 鼠 标 移动 到 菜单 项 上 时 ， 就 会 显示 提示 信息 ， 效 果 如 图 3.75 所 示 。 
明日 图 书 ”深入 社区 ”企业 简介 意见 反馈 


图 3.75 解释 型 菜单 


图 关键 技术 


本 实例 主要 应 用 超 链接 中 的 title 属性 实现 解释 型 菜单 。 在 定义 超 链 接 时 为 其 设置 title 属性 ， 就 可 以 实现 菜 
单 的 提示 功能 ， 例 如 : 
<a href="#" title =" 为 图 书 用 户 提供 在 线 答疑 服务 "> 明日 图 书 &nbsp;&nbsp; </a> 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 
(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 表格 的 第 2 行 再 添加 一 个 1 行 4 列 的 表格 。 
(3) 在 风 套 的 表格 中 加 入 超 链接 ， 主 要 代码 如 下 : 
<td width="123" scope="col" align="right"> <a href="#" title = "为 图 书 用 户 提供 在 线 答 疑 服务 "> 明日 图 书 &nbsp;&nbsp; </a></td> 
<td width="79" scope="col" align="right"><a href="#" title = "为 编程 人 员 提供 一 个 在 线 交流 平台 "> 编程 社区 &nbsp:&nbsp;</a></td> 


<td width="78" scope="col" align="right"><a hre 全 "#"> 企 业 简介 &nbsp:&nbsp;</a></td> 
<td width="82" scope="col" align="right"><a href-"#f"> 意 见 反馈 &nbsp:&nbsp;</a></td> 


图 秘笈 心 法 


心 法 领悟 219: 使 用 CSS 样式 统一 超 链接 效果 。 

在 设计 表单 页 面 时 ， 通 常 需要 统一 某 一 类 表单 元 素 的 效果 。 例 如 ， 统 一 超 链接 文本 字体 的 大 小 、 文 本 颜色 
等 。 一 种 简单 的 方式 是 利用 CSS 样式 来 实现 ， 例 如 : 

<style> 


力 实例 说 明 
网 站 中 的 导航 菜单 是 网 站 首页 必 不 可 少 的 表单 元 素 。 美 观 、 新 颖 的 导航 菜单 会 为 网 站 增色 许多 。 本 实例 将 
现 一 个 半 透 明 效果 的 菜单 ， 效 果 如 图 3.76 所 示 。 
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坚 初 创新 竺 学 笃 行 


| 明日 图 书 | 明日 软件 | 编程 体验 | 编程 误 源 | 内 部 论坛 | 


图 3.76 半 透 明 效 果菜 单 


力 关键 技术 


半 透 明 效果 的 菜单 可 以 通过 CSS 样式 中 的 滤 镜 filter 来 实现 。 在 滤 镜 中 使 用 alpha 属性 设置 透明 程度 (范围 
0~100，0 表示 完全 透明 ，100 表示 不 透明 ) ， 其 语法 格式 如 下 : 
{Filter:alpha(opacity=opacity,finishopacity=finishopacity,sytle=sytlestartx=startx,starty=starty,finishx=finishx, 
finishx=finishyx)} 


例如 ， 下 面 的 语句 将 滤 镜 透明 程度 设置 为 50%。 
Filter: Alpha(Opacity=50); 


设计 过 程 


(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 
(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 第 2 行 中 再 添加 一 个 1 行 3 列 的 表格 。 
(3) 定义 CSS 样式 表 ， 设 置 超 链 接 的 效果 和 半 透 明 菜单 的 效果 ， 代 码 如 下 : 
<style type="text/css"> 
全 blue; FONT-SIZE: 10pt TEXT-DECORATION: none:color:#FF6600 
二 { 
COLOR: black: FONT-SIZE: 10pt;color:#395531 
i { 
BORDER: #666666 1px solid; 
FONT: 12px Verdana; 
POSITION: absolute: 
background-image:url("images/item_out:jpg"): 
background-repeat : repeat-y; 
Filter: Alpha(Opacity=50); 
Sole 
(4) 利用 JavaScript 脚本 控制 菜单 的 显示 与 隐藏 ， 代 码 如 下 : 
<script language="javascript"> 
function ShowMenu(divID, menulten) { // 显 示 子 菜单 
if (document.alD){ 
Switch (menultem){ 
case ' 网 站 导航 ": 


{ 
var htmltxt = "<a href = "www.mingribook.com'> 明日 图 书 网 站 </a> <br> <a href= 
"www.mrbccd.cn'> 明日 编程 社区 </a> <br> <a href= www.mrsoft.com'> 明日 软件 </a> <br>"; 


MenuID innerHTML = htmltxt: /设置 DIV 代码 
MenuID.style .padding = "5px": /设置 DIV 边 距 
MenuID.style .height = "55px": /设置 DIV 高 度 
break: 

} 

case ' 技 术 支 持 ': 


{ 
var menutxt = "<a href = wwwmingribook com> QQ </a> <br> <a href = www.mrbccd. cn’> 
MSN </a> <br> <a href = www.mrsoft.com'> Phone </a> <br>"; 


MenuID innerHTML = menutxt: /设置 DIV 代码 
MenuID.style. padding = "5px": /设置 DIV 边 距 
MenuID.style height = "55px": /设置 DIV 高 度 
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break: 
上 


1! 

/设置 菜单 显示 位 置 

MenuID .style.left = document.body.scrollLeft + event clientX - event.offsetX;: 
MenuID style top = document body scrollTop + eventclientY - event.offsetY + 18 ; 
MenuID style .display 一 "block': 


} 
和 
MenuID .style.display = "none": /隐藏 DIV 
} 
document.onmousemove = HideMenu: /鼠标 在 表单 中 移动 时 隐藏 菜单 
} 


图 秘笈 心 法 


心 法 领悟 220: 设置 鼠标 移动 到 超 链接 的 效果 。 
在 使 用 超 链 接 时 通常 会 为 超 链接 设置 一 些 特效 。 例 如 ， 当 用 户 鼠 标 移动 或 单 击 超 链 接 时 文本 颜色 发 生变 化 。 


要 实现 这 一 功能 最 简单 的 方式 是 定义 CSS 样式 表 ， 例 如 : 
ee 10pt 
Color:#395531 
} 


六 | 
趣味 指数 : 售 侠 催 侠 | 


力 实例 说 明 


二 级 导航 菜单 是 许多 网 站 通常 采用 的 菜单 导航 形式 。 顶 行 显示 一 级 菜单 ， 其 下 显示 二 级 菜单 。 当 用 户 选择 
不 同 的 一 级 菜单 时 ， 二 级 菜单 会 动态 发 生变 化 。 本 实例 就 实现 这 种 效果 的 导航 菜单 ， 如 图 3.77 所 示 。 


图 3.77 二 级 导航 菜单 


力 关键 技术 


实现 二 级 导航 菜单 的 关键 是 二 级 菜单 的 显示 。 当 用 户 选择 不 同 的 顶层 菜单 时 需要 显示 不 同 的 二 级 菜单 。 这 
里 我 们 用 DIV 作为 二 级 导航 菜单 的 容器 ， 通 过 动态 设置 DIV 对 象 的 innerHTML 属性 来 实现 动态 显示 二 级 菜单 
的 效果 。 
图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 
(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ， 在 第 1 行 中 再 添加 一 个 1 行 4 列 的 表格 ,在 第 2 
行 再 添加 一 个 1 行 2 列 的 表格 。 表 单 代码 如 下 : 
<form id="form1" name—"form1" method—"post" action—""> 


<table width="610" height="441" border="0" align="center"> 
<tr> 


279 


PHP 开发 实战 1200 例 (第 I 卷 ) 


<th height="62" align="right" valign="bottom" scope="col"><table width="337" border="1" align="right" cellpadding="0" cellspacing="0" 
bordercolor="#993399" background="images/menuBK.JPG"> 
<t> 
<td width="327" scope="col"> <a href = 六 onmousemove= MenuCtrl( 论 坛 中 心 'subMenu"):> 论 坛 中 心 <a></td> 
<td width="327" scope="col"><a href = 娄 onmousemove=MenuCtrl( 勘 误 发 布 ''subMenu");> 勘 误 发 布 </a></td> 
<td width="327" scope="col"><a href = 学 onmousemove=MenuCtrl( 作 品 展示 ''subMenu):> 作 品 展示 </a></td> 
<td width="327" scope="col"><a href = 沼 onmousemove=MenuCtrl( 联 系 我 们 ''subMenu"):> 联 系 我 们 </a></td> 
</t> 
</table></th> 
<> 
<tr valign="top"> 
<td height="373"><table width="606" border="0" align="center"> 
<t> 
<th width="283" scope="col">&nbsp:</th> 
<th width="313" scope="col"><div id="subMenu" align="left"></div></th> 
</t> 


(3) 利用 JavaScript 脚本 控制 二 级 菜单 的 显示 ， 代 码 如 下 : 


<script language="javascript"> 


Var curSel =""; 
function MenuCtrl(menuID, divID){ 
var divObj = document.getElementById(divID); /获取 DIV 对 象 
if (divObi mlD{ 
Teturn; 
} 
switch (menuID){ 1/ 判断 项 层 菜单 
case ' 论 坛 中 心 : 
{ 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = #>Visual C++ |<a href = #> Visual Basic |<a href = #> PHP </a>"; 
curSel 二 论坛 中 心 '; 
break: 
} 
case ' 勘 误 发 布 " 
{ 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href= 党 > 光 盘 错误 |<a href= > 文档 错误 |<a href = 类 > 目录 错误 </a>"; 
cursel = ' 勘 误 发 布 : 
break: 
1 
case 作品 展示 
/在 DIV 中 显示 子 菜单 


divObj.innerHTML = "<a href= 党 > 视频 学 VB |<a href = 岁 > 视频 学 VC |<ahref= 尝 > 
视频 学 Asp net |<a hre 全 > 视频 学 C# </a>"; 
curSel = ' 作 品 展 心 : 


break: 
} 
case 联系 我 们 ": 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = #>OICQ |<a href = #> MSN|<a href = 党 > Phone</a>"; 
curSel = 联系 我 们 '; 
break: 
} 
和 
L 
if(document.al){ 
MenuCtl( 论 坛 中 心 . 'subMenu); /与 认 情况 下 显示 第 一 个 项 层 菜 单 的 二 级 菜单 项 
} 
</script> 
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图 秘笈 心 法 

心 法 领悟 221: 设置 表格 单 边框 效果 。 

默认 情况 下 ， 表 格 具 有 双边 框 ， 在 利用 表格 进行 界面 布局 时 这 种 效果 会 影响 页 面 的 美观 性 。 我 们 可 以 通过 
将 表格 的 cellspacing 属性 设置 为 0 来 实现 表格 的 单 边框 效果 ， 例 如 : 

<table width="337" border="1"” cellspacing="0" bordercolor="#993399" background=-"imagesimenuBK .JPG"> 

趣味 指数 ; 祖 育 育 育 ， 


力 实例 说 明 


导航 条 是 网 站 设计 中 不 可 缺少 的 元 素 之 一 ， 它 能 正确 地 引导 浏览 者 查找 需要 的 资料 ， 成 为 浏览 者 的 网 站 路 
标 。 同 时 网 页 导航 条 的 设计 风格 也 能 影响 到 页 面 的 整体 风格 ， 对 于 一 个 静态 元 素 居 多 的 页 面 ， 可 以 为 导航 条 添 
加 动态 效果 ， 这 样 可 以 使 整个 网 站 不 至 于 太 呆 板 ， 增 强 网 页 的 欣赏 价值 。 例 如 ， 在 明日 实业 网 站 中 ， 笔 者 将 导 
航 条 设计 成 动画 效果 ， 用 户 将 鼠标 移动 到 任意 一 个 导航 按钮 上 时 ， 该 按钮 都 会 突出 显示 ， 鼠 标 移出 后 ， 又 恢复 
为 原来 的 位 置 ， 运 行 结果 如 图 3.78 所 示 。 


图 3.78 ”导航 条 的 动画 效果 


力 关键 技术 


本 实例 主要 是 通过 Image 对 象 的 鼠标 事件 控制 Image 对 象 的 src 属性 的 值 实现 的 。 

在 JavaScript 里 提供 了 对 图 像 进行 处 理 的 专用 对 象 Image 来 装 入 文档 的 图 形 。Image 对 象 与 其 他 对 象 的 差别 
在 于 ,其 允许 通过 构造 器 显示 和 创建 新 的 Image 对 象 , 创造 和 预 装 入 的 图 形 之 前 并 非 Web 页 面 的 组 成 部 分 .Image 
对 象 存在 于 浏览 器 的 缓冲 区 中 ， 用 于 替换 已 经 显示 的 图 像 。 

用 Image0 构 造 器 创建 图 形 的 语法 格式 如 下 : 


ObjImg=new imageO) /创建 了 一 个 新 的 Image 对 象 ， 并 将 其 赋予 变量 ObjImg 
ObjImg.sre=" 图 片 文件 相对 路 径 " /设置 Image 对 象 的 Src 属性 
图 设计 过 程 


(1) 准备 14 张 图 片 。7 张 鼠标 移出 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 +.gif”，7 张 鼠 标 
移入 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 + _over.gif”。 
(2) 将 准备 的 7 张 鼠标 移出 时 显示 的 图 片 按 顺序 插入 到 页 面 中 的 适当 位 置 ， 并 设置 其 鼠标 事件 
onMouseMove 和 onMouseout 执行 的 操作 ， 这 里 分 别 调用 两 个 不 同 的 自 定义 JavaScript 函数 ， 关 键 代 码 如 下 : 
<img src="Images/top/menu 01.gif" id-"imagel" width="95" height="119" border="0" onMouseMove—"move(this.1)" onMouseout="out(this,1)"> 
<img src="Images/top/menu 02.gif" id-"image2" width="95" height="119" border="0" onMouseMove—"move(this.2)" onMouseout="out(this,2")"> 
<img src="Images/top/menu 03.gif" name="image3” width="95" height="119" border="0" onMouseMove="move(this,3)" 
onMouseout="out(this,'3)"> 
<img sre—"Images/top/menu 04.gif name—"image4" width-"94" height-"119" border—"0" onMouseMove—"move(this,'4")" onMouseout—"out(this,4)"> 
<img src="Images/top/menu 05.gif" name="image5" width="95" height="119" border="0" onMouseMove="move(this,'5)" onMouseout="out(this,'5)"> 
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<img src="Images/top/menu 06.gif" name="image6" width="94" height="119" border="0" onMouseMove="move(this..6)" onMouseout="out(this,6)"> 
<img src="Images/top/menu 07.gif" width="95" name="image7" height="119" border="0" onMouseMove="move(this.'7)" onMouseout="out(this,7)"> 


(3) 编写 自 定义 的 JavaScript 函数 move0 和 out0，move0 用 于 设置 鼠标 移入 导航 按钮 时 显示 的 图 片 ，outO 


用 于 设置 鼠标 移出 导航 按钮 时 显示 的 图 片 ， 代 码 如 下 : 


<script language="javascript"> 

/鼠标 移动 效果 

var A_Img=new Image0; 

function move(image,num){ 
image.src=Tmages/top/menu 0+numf+' over.gif; 
} 

function out(image,num){ 
image.sre=Tmages/top/menu 0'+numt.gif; 

} 

</script> 


图 秘笈 心 法 


心 法 领悟 222: Image 构造 器 。 

用 Image0 构 造 器 创建 图 形 的 语法 格式 如 下 : 

ObjImg=new image0 /创建 了 一 个 新 的 Image 对 象 ， 并 将 其 赋予 变量 ObjImg 

ObjImg.sre=" 图 片 文件 相对 路 径 " /设置 Image 对 象 的 Src 属性 

在 利用 Image 对 象 编程 之 前 ， 利 用 <img> 标 记 显示 属性 。 在 HTML 中 ， 要 显示 图 片 可 以 用 如 下 语句 来 实现 : 
<img src="pictureName.gif' name="ImgName"> 

在 JavaScript 中 可 以 用 下 面 的 方式 访问 Image 对 象 : 

document.Img.sre=" menu 01.gif"; 
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41 文件 上 传 


文件 上 传 是 网 站 中 一 个 非常 重要 的 功能 ， 特 别 是 在 网 站 的 后 台 管理 系统 中 ， 需 要 通过 此 功能 向 网 站 中 上 传 
很 多 数据 ， 包 括 图 片 、 文 件 等 。 


图 实例 说 明 

文件 的 上 传 可 以 分 为 两 类 : 一 类 是 上 传 文件 到 服务 器 ， 即 存储 到 服务 器 指定 的 文件 夹 下 ， 另 一 类 是 将 数据 
以 二 进 制 的 形式 上 传 到 数据 库 中 。 具 体 采用 哪 种 方式 ， 需 要 根据 程序 的 实际 需要 而 定 。 

本 实例 中 将 介绍 如 何 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 中 ， 并 且 输 出 上 传 的 数据 。 运 行 结果 如 图 4.1 
所 示 。 


天 便 息 管理 ] [ # 小 分 英信 息 答 理 ] [ 二 活 加 丙 品 信息 ] 


添加 图 书 Acquisition 
Sh: PP | 
73 人 i 格 : 加 | 
wa 70 


出 二 福 : 


图 和 而 介 : 


ee 购 电子 商城 守 记 服务 热 编 ; Dt31-B4sres61 ,etorasee 传真 : 0431-94972266 
Copyhight @ 2005 we nixgrisoft. com 吉林 省 明日 科技 有 限 公司 
本 站 请 使 用 IE8.0 或 以 上 版 本 1024xT68 为 蘑 侍 显示 获 果 


图 4.1 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 


图 关键 技术 


本 实例 主要 应 用 表单 中 的 文件 域 提交 图 片 文件 代码 如 下 : 

<input name='cover' type—"file" id—"cover" size—"30"> 

其 中 ， 参 数 type 指定 表单 元 素 的 类 型 为 文件 域 ，name 指定 表单 元 素 的 名 称 ，size 指定 表单 元 素 的 大 小 。 

通过 $_POST[] 方 法 获取 表单 中 提交 的 数据 ， 并 应 用 insert 语句 将 表单 中 的 数据 添加 到 数据 表 中 。Insert 语句 
的 语法 如 下 : 

Insert into table_name (column name,column name2. ... ) values (valuel, value2. ... ) 

参数 说 明 : 

table name: 数据 表 的 名 称 。 
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column: 数据 表 中 字段 的 名 称 。 

valuel: 表单 提交 的 变量 。 

在 index_ok.php 文件 中 ， 通 过 fopen0 函 数 和 fread0 函 数 读 取 表 单 中 提交 的 图 片 数 据 ， 并 且 将 返回 的 数据 存 
储 到 数据 库 中 。 

在 这 里 要 特别 注意 网 页 编码 格式 的 使 用 。 如 果 网 页 的 编码 格式 是 UTF-8， 那 么 在 获取 上 传 文件 的 存储 路 径 
时 ， 必 须 将 UTF-8 编码 格式 的 字符 串 转换 为 gb2312 编码 格式 ， 否 则 文件 不 能 被 fopen0 函 数 读 取 。 


图 设计 过 程 
(1) 通过 Dreamweaver 开发 工具 创建 一 个 index.php 页 , 添加 一 个 表单 ,设置 表单 的 method 属性 值 为 post， 
设置 表单 的 Action 属性 值 为 ndex_ok.php; 添加 表单 元 素 ， 提 交 图 书信 息 ; 添加 提交 按钮 ， 其 关键 代码 如 下 : 


<form name="form" method="post" action="index ok.php" onSubmit="returmn check form(this)"> 
<input name="cover" type="file" id="cover" size="30"> 

<input type="submit" name="Submit" value=" 提 交 "> 
</form> 


(2) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 连 接 MySQL 数据 库 服 务 器 ， 连 接 db_database04 数据 库 ， 设 
置 数据 库 变 量 格式 为 utf8。 

(3) 创建 index_ok.php 文件 , 通过 $_POST[] 方 法 获取 表单 中 提交 的 数据 , 并 判断 上 传 图 片 的 格式 是 否 正确 ， 
通过 fopen0 函 数 和 freadO 函 数 读 取 表单 中 提交 的 图 片 数据 ， 编 写 insert 语句 将 数据 添加 到 指定 的 数据 表 中 ， 其 


关键 代码 如 下 : 
<2php 
include("conn/conn.php"); // 连 接 数 据 库 
Sbookname=$_POST["bookname"]; /获取 表单 中 提交 的 数据 


S$price=$_POST["price"]; 
Smaker=$ POST["maker"]: 
SissuDate=$_POST["issuDate"]; 
S$publisher=$_POST["publisher"]; 
$synopsis=$ POST["synopsis"]; 


Scover=$_POST["cover"]: // 获 取 表 单 中 提交 的 图 片 
这 $_POST["Submit"] 一 tmejf 
Scover_type=strstr(Scover,"."); /1/ 获 取 从 “.” 到 最 后 的 字符 
这 $cover type != "jpg" && $cover type !=".gif’ &é&: $cover type (= ".JPG" && $cover type != "GIF" && $cover type (=".bmp" && 
Scover type (= ".BMP"){ /判断 图 片 的 格式 
echo "<script>alert( 封 面 图 片 格式 不 对 ， 请 进行 处 理 后 在 上 传 ! "); window.location.href='index.php';</script>"; 
Jelse{ 
Scover=iconv("utf-8","gb2312",$cover): /设置 字 符 串 的 编码 格式 
S$fp=fopen($cover,"rb"); /以 二 进 制 形 式 打开 图 片 
Simage=addslashes(fread($fp,filesize($cover))); / 读 取 二 进 制 的 数据 
$sql="insert into tb_book(bookname,price.maker,issuDate,publisher,synopsis.cover) values('$bookname’, 
‘Sprice''$maker','$issuDate','$publisher’,'$synopsis','Simage)"; // 将 数据 添加 到 指定 的 数据 表 中 
Sresult=mysql_query($sql,$conn); 
/省 略 了 部 分 代码 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 223: 读 取 数据 库 中 存储 的 二 进 制图 片 数 据 。 

读 取 数 据 库 中 存储 的 二 进 制图 片 数 据 需 要 定义 一 个 单独 的 文件 ， 根 据 数据 的 ID 值 执行 查询 ， 并 应 用 
mysql_reult0 函 数 返 回 查询 结果 ， 最 后 输出 查询 结果 。 本 实例 中 定义 的 是 images.php 文件 ， 通 过 该 文件 完成 对 数 
ee - 进 制图 片 的 读 取 操作 。images.php 的 代码 如 下 : 


ee ‘conn/conn.php"); /连接 数据 库 
$query="select * from tb_book where id=".$_GET[recid]: // 定 义 查询 指定 数据 的 语句 
Sresult=mysql_query($query); /执行 查询 
这 !Sresult) die("error: mysql query"): /返回 失败 的 结果 
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| num rows(Sresulb: /获取 查询 结果 的 数量 
if($num<1) die("error: no this recorder”"): // 如 果 查 询 结果 小 于 则 说 明 没 有 数据 
S$data = mysql_result($result.0."cover"); /获取 查询 结果 
mysql_close($conn): /关闭 数据 库 
echo $data; /输出 返回 的 数据 
> 
f 言 级 : 
。 上 
实例 224 3 | 
趣味 指数 : 走穴 走 丰 页: 
有 
图 实例 说 明 


在 开发 网 站 的 过 程 中 ， 不 但 可 以 将 文件 上 传 到 数据 库 中 ， 而 且 可 以 将 文件 上 传 到 服务 器 ， 这 种 方式 可 以 为 
网 站 中 的 数据 库 节 省 很 多 空间 ， 同 时 可 以 控制 上 传 文件 的 大 小 、 格 式 ， 并 且 读 取 服 务 器 中 的 文件 要 比 从 数据 库 
中 读 取 方便 很 多 。 运 行 本 实例 ， 如 图 4.2 所 示 ， 单 击 图 中 的 “浏览 ”按钮 ， 选 择 要 上 传 的 文件 ， 然 后 单 击 “ 提 
交 ” 按 钮 ， 如 果 上 传 成 功 ， 则 在 页 面 中 提示 “上 传 成 功 ! ”， 否 则 给 出 错误 提示 信息 。 
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Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 4.2 上 传 文件 


力 关键 技术 


PHP 中 ， 应 用 move_uploaded_file0 函 数 实现 将 文件 上 传 到 指定 文件 夹 。 但 是 ， 在 执行 文件 上 传 之 前 ， 为 了 
防止 潜在 的 攻击 对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 , 可 以 先 应 用 is_uploaded_file0 函 数 判断 指定 的 文 
件 是 否 是 通过 HTTP POST 上 传 ， 如 果 是 则 返回 TRUE。is_uploaded_file0 函 数 的 语法 如 下 : 

bool is_uploaded file ( string filename ) 

参数 filename 必须 指定 类 似 于 $_FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 
$_FILES[filename'][mame']。 

通过 is_uploaded_file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 
件 ， 例 如 /etc/passwd。 

move_Uploaded fileO 函 数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返 回 TRUE， 否 则 返回 FALSE， 其 
语法 如 下 : 

bool move_uploaded file ( string filename. string destination ) 

参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指定 文件 上 传 后 保存 的 
新 路 径 和 名 称 。 


说 明 : 如 果 参 数 flename 不 是 合法 的 上 传 文件 ， 不 会 出 现任 何 操作 ，move Uploaded file() 将 返回 FALSE。 
如 果 参 数 flename 是 合法 的 上 传 文件 ， 但 出 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ， 
Imove Uploaded file0 将 返回 FALSE， 此 外 还 会 发 出 一 条 警告 。 
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(1) 创建 index.php 文件 ,添加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 
使 用 POST 方法 ， 将 表单 中 数据 提交 到 本 页 。 
(2) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move upload file0 函 数 完成 图 片 的 上 传 ， 代 码 如 下 : 


<?php 

if(!empty($_FILES[up_picture][name]){ // 淹 断 上 传 内 容 是 否 为 室 

这 $_FILES[up_picture][error]>0){ /判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 


switch($_FILES[up_picture']['erorD) { 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 ": 
break; 


Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
Case 3: 
echo "上 传 文件 不 全 "; 
break; 


Case 4: 
echo "没有 上 传 文件 "; 
break; 


} 
yelse{ 
if(!is_dir("./upfile/"){ // 判 断 指定 目录 是 否 存在 
mkdir("./upfile/"); // 创 建 目录 
} 


Spath=",/upfile/".time().strstr($_FILES['up_picture']['name’],’.): // 定 义 文件 名 称 和 存储 位 置 
iflis_uploaded file($_FILES['"up_picture]["tmp_name']){ /是 否 是 HITP POST 上 传 
if(!move_uploaded file($_FILES[up_picture]['mp_name'].Spatb))f /| 执行 上 传 
echo "上 传 失败 "; 
jelsef 
echo "文件 "time0.S_FILES[up_picture][name]" 上 传 成 功 ， 大 小 为 : "S_FILES[up_picture][size]; 


} 
jelse{ 
echo "上 传 文件 "S_FILES[up_pictute][mame]." 不 合法 ! “: 
} 
上 


} 
> 


图 秘笈 心 法 


心 法 领悟 224: 通过 表单 中 的 隐藏 域 控制 上 传 文件 的 大 小 。 

如 果 应 用 $_FILES[picture]['error] 对 上 传 文件 的 信息 进行 判断 ， 当 其 返回 值 为 2 时 , 说 明 上 传 文件 的 大 小 超 
出 了 表单 中 约定 的 范围 ， 而 表单 中 的 这 个 约定 值 是 通过 隐藏 域 MAX FILE_SIZE 的 值 来 控制 的 。 在 设置 这 个 隐 
藏 域 时 ， 必 须 将 其 放置 在 文件 域 之 前 ， 否 则 不 起 作用 。 


趣味 指数 : 太 丰 页 直 在， 


力 实例 说 明 


在 网 站 开发 的 过 程 中 ， 为 了 确保 充分 地 利用 服务 器 的 空间 ， 在 开发 上 传 功能 时 最 好 能 够 对 上 传 文件 的 大 小 
进行 控制 。 本 实例 开发 的 上 传 功能 就 可 以 对 上 传 文件 的 大 小 进行 控制 。 如 果 上 传 文件 的 大 小 超过 指定 范围 ， 那 
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么 将 给 出 提示 信息 ， 并 终止 上 传 。 运 行 效果 如 图 4.3 所 示 。 
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上 传 图 片 大 小 为 28 


上 做 错误 -上 传 文件 大 小 超出 配置 文件 规定 值 
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图 4.3 限制 上 传 文件 的 大 小 


图 关键 技术 


控制 上 传 文件 的 大 小 有 两 个 关键 点 : 第 一 点 是 PHP 的 配置 文件 php.ini 对 上 传 文件 的 控制 , 如果 上 传 文件 的 
大 小 超过 其 指定 的 范围 ， 那 么 上 传 就 会 执行 失败 ; 第 二 点 是 在 PHP 配置 文件 允许 的 范围 内 ， 在 程序 中 对 上 传 文 
件 大 小 的 控制 。 
(1) 在 PHP 中 ， 通 过 php.ini 文件 对 上 传 文件 进行 控制 ， 包 括 是 否 支 持 上 传 、 上 传 文件 的 临时 目录 、 上 传 
文件 的 大 小 、 指 令 执行 的 时 间 、 指 令 分 配 的 内 存 空间 。 
在 php.ini 中 ， 定 义 到 File Uploads 项 ， 完 成 对 上 传 相关 选项 的 设置 。 上 传 相关 选项 的 含义 如 下 : 
file_uploads: 如 果 值 是 on， 说 明 服务 器 支持 文件 上 传 ; 如 果 为 off， 则 不 支持 。 一 般 默认 是 支持 的 ， 
不 需 修 改 。 
upload_tmp_dir 上 传 文件 的 临时 目录 。 在 文件 被 成 功 上 传 之 前 ， 首 先 存放 到 服务 器 端的 临时 目录 中 。 
多 数 使 用 系统 默认 目录 ， 但 是 也 可 以 自行 设置 。 
Upload max _filesize: 服务 器 允许 上 传 文件 的 最 大 值 ， 以 MB 为 单位 。 系 统 默 认为 2MB， 如 果 网 站 需 
要 上 传 超过 2MB 的 数据 ， 那 么 就 要 修改 这 个 值 。 
上 述 是 php.ini 的 File_ Uploads 项 中 与 上 传 相 关 选 项 参数 的 设置 说 明 ， 除 了 File_ Uploads 项 中 的 内 容 外 ， 在 
php.ini 中 还 有 其 他 几 个 选项 会 影响 到 文件 的 上 传 。 
max_execution time: PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 秒 。 在 上 传 超大 文件 时 必须 修改 该 
选项 ， 和 否则 即使 上 传 文件 在 服务 器 允许 的 范围 内 ， 若 是 超过 了 指令 所 能 执行 的 最 大 时 间 ， 仍 然 无 法 实 
现 上 传 。 
回 “memory_limit: PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 MB， 其 大 小 同样 会 影响 到 超大 文件 的 
上 传 。 
(2) 在 客户 端 控 制 上 传 文件 ， 应 用 的 是 form 表单 中 的 enctype 和 method 属性 ， 以 及 隐藏 域 MAX_FILE_ 
SIZE。 
enctype="multipart/form-data"， 指 定 表单 编码 数据 方式 。 
method="post"， 指 定数 据 的 传输 方式 。 
<input type="hidden" name="MAX FILE SIZE" value="10000" />, 通过 隐藏 域 控制 上 传 文件 的 大 小 ( 单 
位 为 字 节 ) ， 该 值 不 能 超过 php.ini 配置 文件 中 upload_max_filesize 选项 设置 的 值 。 它 不 能 完全 控制 上 
传 文件 的 大 小 ， 只 是 可 以 避免 一 些 不 必要 的 麻烦 。 
上 述 两 种 判断 的 结果 都 可 以 通过 全 局 变量 $_FILES 的 返回 值 来 体现 。$_FILES 是 一 个 数组 ， 包 含 所 有 上 传 
文件 的 信息 。 下 面 介绍 一 下 $_FILES 数组 中 每 个 元 素 的 含义 ， 如 表 4.1 所 示 。 


图 图 轿 
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表 4.1 $_FILES 数组 中 的 元 素 


元 素 名 说 了 明 
$_FILES[filename][name] 存储 上 传 文件 的 文件 名 ， 如 : text.txt、title.jpg 等 
$ FILES[filenamej[size] 存储 文件 大 小 ， 单 位 为 字 节 
$ FILES[filename J[tmp name] 存储 文件 在 临时 目录 中 使 用 的 文件 名 。 因 为 文件 在 上 传 时 ， 首 先 要 将 其 以 临时 文件 的 身 
和 份 保存 在 临时 目录 中 
存储 上 传 文件 的 MIME 类 型 ,MIME 类 型 规定 各 种 文件 格式 的 类 型 。 每 种 MIME 类 型 都 
$_FILES[filename][type] 是 由 “/” 分 隔 的 主 类 型 和 子 类 型 组 成 。 例 如 image/gif， 主 类 型 为 “图 像 ”， 子 类 型 为 


GIF 格式 的 文件 ，text/html 代表 文本 的 HTML 文件 

存储 与 文件 上 传 相关 的 错误 代码 。 此 项 目 是 PHP 4.2.0 版 本 中 新 增 的 内 容 ， 其 返回 值 有 
5 种 ， 如 下 所 示 : 

0: 表示 没有 任何 错误 ， 文件 上 传 成 功 

1: 表示 上 传 文件 的 大 小 超出 了 PHP 配置 文件 指令 upload_max_filesize 选项 限制 的 值 

2: 表示 上 传 文件 的 大 小 超出 了 HTML 表单 中 MAX_FILE_SIZE 选项 所 指定 的 值 

3: 表示 文件 只 被 上 传 了 一 部 分 

4: 表示 没有 上 传 任何 文件 


$_FILES[filename][error] 


图 设计 过 程 
(1) 创建 index.php 文件 。 
(2) 创建 index.php 文件 ,添加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 
使 用 POST 方法 将 表单 中 数据 提交 到 本 页 。 
(3) 通过 $ FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload file0) 函 数 完成 图 片 的 上 传 ， 代 码 如 下 : 
ph 
iemmpg(s_FILESIup pieture]fnameD){ / 莘 断 上 传 内 容 是 否 为 
这 $_FILES[up_picture][error]>0){ 1/ 判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 
switch($_FILES['up_picture]['errorD){ 
case 1 


echo "上 传 文件 大 小 超出 配置 文件 规定 值 " 
break; 


Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 


Case 3: 
echo "上 传 文件 不 全 "; 
break: 


case 4: 
echo "没有 上 传 文件 "; 
break: 


， 
Jelse{ 
if(!is_dir("./upfile/") { 1/ 判断 指定 目录 是 否 存 在 
mkdir("./upfile/”): /| 创建 目录 


} 
S$path=' ,upfile/'timeO.strstr($_FILES[up_picture][mame]7: /定义 文件 名 称 和 存储 位 置 
iftis_uploaded file($_FILES[up_picture]['tmp_name])){ /是 否 是 HITP POST 上 传 
if(!move_uploaded file($_FILES[up_picture][tmp_name].Spatb)){ /执行 上 传 
echo "上 传 失败 ": 
Jelse{ 
echo "文件 "time0.$_FILES[up picture][name]" 上 传 成 功 ， 大 小 为 : "$_FILES[up_picture][size]: 


} 
Jelse{ 

echo "上 传 文件 ".S_FILES[up_pictute][mame']." 不 合法 ! "; 
} 
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> 


图 秘笈 心 法 

心 法 领悟 225: 如 何 上 传 超大 文件 。 

如 果 要 上 传 超大 文件 ， 必 须 修 改 php.ini 文件 。 修 改选 项 包括 : upload max filesize 的 最 大 值 、 
max_execution_time 一 个 指令 所 能 执行 的 最 大 时 间 和 memory_limit 一 个 指令 所 分 配 的 内 存 空间 。 


中 级 
直 吐 指数， 页 机 页 


图 实例 说 明 


在 开发 文件 上 传 功能 时 ， 不 只 要 考虑 上 传 文件 的 大 小 ， 有 时 还 要 考虑 上 传 文件 的 类 型 ， 针 对 不 同 的 需要 对 
上 传 文件 的 类 型 加 以 限制 ， 这 里 指 的 文件 类 型 可 以 通过 文件 的 扩展 名 例如 .txt、.php、.doc》 来 判断 。 例 如 ， 
在 进行 文件 上 传 时 ， 涉 及 到 文本 说 明 性 文字 时 ， 最 好 将 上 传 的 文件 限制 为 以 “.txt” 为 后 级 的 文本 格式 。 

运行 本 实例 ,如 图 4.4 所 示 , 单 击 图 中 的 “浏览 ”按钮 ， 选择 要 上 传 的 文件 (文件 不 是 以 “.txt” 为 扩展 名 )， 
单 击 “ 提 交 ” 按 钮 ， 程 序 将 给 出 错误 提示 。 
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图 4.4 限制 上 传 文件 的 类 型 


图 关键 技术 


文件 的 上 传 和 对 大 小 的 限制 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 只 讲解 限制 上 传 文件 类 型 的 关键 技术 ， 首 先 
要 通过 预定 义 全 局 变量 $_ FILES 中 的 $ FILES[files][name] 获 取 上 传 文件 的 名 称 ， 然 后 应 用 strstr0 截 取 上 传 文件 
名 称 的 后 级 ， 最 后 判断 上 传 文件 的 后 级 是 否 符合 要 求 。 

strstr0 函 数 的 语法 如 下 : 

string strstr(string strings, string needle); 

该 函数 用 于 在 字符 串 strings 中 查找 字符 串 needle 的 位 置 , 并 返回 从 needle 字符 串 开始 到 strings 字符 串 结 束 
的 所 有 内 容 ， 如 果 在 strings 中 没有 查找 到 needle， 该 函数 将 返回 FALSE。 


力 设计 过 程 
(1) 继续 使 用 实例 225 的 内 容 ， 在 其 基础 上 增加 对 上 传 文件 类 型 的 判断 ， 增 加 的 关键 代码 如 下 : 


<?php 

itempty($_FILES[up_picture][name])){ // 浏 断 上 传 内 容 是 否 为 室 

$type=$_FILES[up_picture][mame]: /获取 上 传 文件 的 名 称 

$types=strstr($type,'.); /截取 上 传 文件 的 后 级 

if($types—".txt"){ 1/ 判断 上 传 文件 的 后 缀 是 否 符合 要 求 
/省略 了 部 分 代码 

} 

jelse{ 
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echo "上 传 文件 ".$_FILES[up_pictute]['name"]." 类 型 不 正确 ! "; 
} 
} 


> 


(2) 重新 保存 index.php 文件 。 
图 秘笈 心 法 


心 法 领悟 226: 判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 。 
判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 ， 最 佳 的 方法 就 是 将 多 种 类 型 定义 到 一 个 数组 中 ， 然 后 通过 for 
循环 输出 数组 中 的 元 素 值 ， 将 输出 的 元 素 值 与 获取 的 文件 后 级 进行 比较 ， 进 而 判断 其 是 否 符 合 要 求 。 


实例 227 


图 实例 说 明 


上 传 图 片 到 服务 器 ， 是 程序 开发 过 程 中 必 不 可 少 的 一 个 功能 。 它 不 但 可 以 达到 图 片 共享 的 目的 ， 而 且 可 
以 提高 网 站 的 访问 量 ， 丰 富 网 站 的 内 容 。 在 本 实例 中 ， 讲 解 如 何 通过 POST 方式 实现 多 图 片上 传 ， 运 行 结果 如 


图 4.5 所 示 。 
® 个 皮 竹 、 的 人 人 同名 
此 文件 上 传 5 一 次 最 多 上 传 :个 图 片 7 
名 称 图 片 路 径 
内 容 1: [ 列 砚 . 
内 容 2， [ Er 
内 容 3， [ EF 
内 容 4 [ 
波 晶 电视 
页 次 : 615 页 记录 : 354 条 i 首页 123456 尾 页 
Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 
图 4.5 POST 方式 实现 多 图 片上 传 
图 关键 技术 


多 文件 上 传 的 关键 是 如 何 定义 上 传 文件 元 素 的 名 称 及 如 何 判断 上 传 文件 的 数量 。 在 本 实例 中 ， 以 数组 的 形 
式 定义 上 传 文件 的 名 称 〈 上 传 文件 的 名 称 是 “files[]”) 。 为 了 达到 可 以 上 传 任意 数量 图 片 〈4 个 图 片 以 内 ) 的 
目的 ， 在 对 上 传 文件 进行 处 理 的 过 程 中 应 用 array_filter0 函 数 和 回调 函数 去 除数 组 中 的 空 元 素 。 

array_filter0 函 数 ， 用 回调 函数 过 滤 数 组 中 的 单元 ， 语 法 如 下 : 

anayanay_ filter ( array input [ callback callback] ) 

array_filter0 函 数 依次 将 input 数组 中 的 每 个 值 传递 到 callback 函数 。 如 果 callback 函数 返回 TRUE， 则 
input 数组 的 当前 值 会 被 包含 在 返回 的 结果 数组 中 ， 并 且 数 组 的 键 名 保留 不 变 。 


上 说 明 : 在 回调 函数 中 不 要 对 数组 进行 修改 操作 ， 例 如 ， 增 加 或 者 删除 数组 中 的 元 素 ， 如 果 一 旦 数组 改变 ， 
那么 此 函数 的 运用 也 就 没有 意义 了 。 如 果 没有 提供 callback0 函 数 ，array_filter0 将 删除 input 中 所 有 
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等 值 为 FALSE 的 元 素 。 


本 实例 中 定义 的 回调 函数 是 check0， 用 于 验证 数组 中 的 元 素 值 是 否 为 空 ， 其 语法 如 下 : 
function check($var) { /验证 数组 的 返回 值 是 否 为 空 

Tetum (Svar (= ""); 
} 


说 明 : 通过 POST 方法 实现 多 图 片上 传 ， 在 创建 form 表单 时 ， 必 须 指定 enctype="multipart/form-data" 属 性 。 
如 果 要 通过 隐藏 域 MAX FILE SIZE 的 值 对 上 传 文件 的 大 小 进行 控制 ， 那 么 必须 将 隐藏 域 放置 在 上 
传 文件 的 文件 域 之 前 ， 否 则 是 不 会 起 作用 的 。 


图 设计 过 程 
(1) 创建 index.php 文件 。 添 加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 ,设置 enctype= 


"multipart/form-data"， 将 数据 提交 到 index_ok.php 页 ， 完 成 多 个 文件 的 上 传 操作 ， 其 关键 代码 如 下 : 
<table width="750" border="0" cellspacing="0" cellpadding="0"> 
<form action="index_ok.html" method="post" enctype="multipart/form-data" name= forml"> 
<t> 
<td width="100" height="25" align="right" class="STYLE1"> 内 容 1: </td> 
<td width="150" align="center"><input name="files[]" type="text" id="files[]" size="15"></td> 


<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 


<t> 
<t> 
<td height="25" align="right" class="STYLE1"> 内 容 2: </td> 


<td align="center"><input name="files[]" type="text" id="files[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 


</a> 
<t> 
<td colspan="3" align="center"> 


<input type="image" name="imageField" src="images/bg 09.ipg">é&nbsp;é&nbsp;é&nbsp; énbsp; 
<input type="image" name="imageField2" src="images/bg_11.jpg"></td> 


</table> 
(2) 在 index.php 文件 中 ， 连 接 数据 库 ， 读 取 数 据 库 中 存储 的 数据 ， 实 现 上 传 文件 的 分 页 输出 。 代 码 请 参 

考 光盘 中 的 相关 内 容 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 多 个 文件 存储 到 服务 器 中 ， 将 文件 的 名 称 和 存储 

人 其 代码 如 下 : 
<?pl 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
// 包 含 数据 库 链接 文件 
] ) 

让 (is dir ("./upfile" )) { 
mkdir ( "./upfile" ); 1/ 创建 上 传 文件 存储 文件 夹 

} 

Sdata = date ("Y-m-d H:m:s" ): // 定 义 时 间 

function check(Svan) { /验证 数组 的 返回 值 是 否 为 空 
Tetum (Svar (= ""); // 如 果 不 为 空 则 返回 数组 元 素 

} 

Sfiles = array_filter ( $_POST ["files"], "check" ); // 去 除数 组 中 空 值 

Sarray =array_filter ( $_FILES ["picture"] ["name"], "check" ); // 去 除数 组 中 空 值 

foreach ( $array as $key => $value ) { /循环 读 取 数 组 中 数据 
Spath = upfile/' . time 0 . $key . strtolower ( strstr ( $value. "." ) ); // 定 义 上 传 文件 存储 位 置 
move_uploaded _file ( $_FILES ["picture"] ["tmp_name"] [$key], $path ); /| 执行 上 传 操作 


Squery = "insert into tb_up_file (file_test.data.file name) values (‘Spath','Sdata'.Sfiles[Skey])": 


Sresult = mysql query ( $query ): 
和 


echo "<script>alert( 图 片上 传 成 功 ); window.location href-index html';</script>"; 
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图 秘笈 心 法 


心 法 领悟 227: 通过 伪 静 态 技术 隐藏 PHP 文件 后 绥 。 
首先 ， 修 改 Apache 服务 器 的 配置 文件 httpd.conf。 打 开 httpd.conf 文件 ， 定 位 到 如 下 位 置 : 


订 oadModule rewrite_module modules/mod rewrite so 

将 该 项 前 面 的 “#” 去 掉 后 启动 该 项 。 

然后 ,查找 httpd.conf 文件 , 找到 其 中 的 AllowOverride 项 , 将 它 的 值 都 修改 为 All。 保存 并 重新 启动 Apache 
服务 器 ， 使 修改 生效 。 


通过 正则 表达 式 对 文件 的 后 级 和 传递 的 参数 进行 匹配 ， 完 成 对 PHP 文件 后 级 的 隐藏 操作 。 


42 文件 下 载 


初级 
赴 水 指数 ; 容 调 站 | 


力 实例 说 明 


在 一 个 完整 的 网 站 中 ， 具 有 文件 下 载 功能 能 够 给 网 站 带 来 更 多 的 访问 者 ， 增 加 网 站 的 访问 量 。 最 常用 的 文 
件 下 载 方 式 就 是 通过 链接 下 载 。 在 本 实例 中 ， 应 用 链接 方式 进行 下 载 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 弹出 文 
件 下 载 的 对 话 框 ， 完 成 下 载 操作 ， 运 行 结果 如 图 4.6 所 示 。 

到 
BDA 可 0 癌 | 


图 4.6 链接 方式 的 文件 下 载 


力 关键 技术 


本 实例 主要 通过 超 链接 来 实现 文件 的 下 载 。 通 过 select 语句 从 数据 库 中 读 取 文 件 存储 的 路 径 ， 然 后 将 该 文 
件 作 一 个 超 链接 ， 当 单 击 “下 载 ” 超 链接 时 ， 即 可 下 载 该 文件 。 


力 设计 过 程 


(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 名 称 创建 超 链接 ， 完 成 图 片 的 下 载 操作 ， 其 关键 代码 如 下 : 
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<a href="<?php echo Smyrow[file test]:?>"><?php echo Smyrow[file name]:?></a> 
(2) 保存 对 文件 的 修改 ， 运 行程 序 ， 运 行 结果 参看 实例 说 明 。 


图 秘笈 心 法 
心 法 领悟 228: 不 同类 型 的 文件 ， 下 载 操作 不 同 。 
如 果 是 压缩 的 文件 可 以 直接 下 载 ， 如 果 不 是 ， 则 需要 单 击 鼠 标 右键 选择 “另存 为 ”命令 。 


中 级 
起 水 可 孝 ， 克 室 二 家 | 


图 实例 说 明 


除了 可 以 通过 链接 方式 下 载 文件 之 外 ， 还 可 以 通过 header0 函 数 完 成 下 载 操 作 。 例 如 ， 本 实例 中 就 是 应 用 
header0 函 数 实现 文件 的 下 载 ， 如 果 下 载 的 文件 不 存在 ， int i 运行 结果 如 图 4.7 所 示 。 


m| 各 和 12759792140.png 
类 型 PNG 图 全 ,1,95 KB 


发 送 午 :127,0.0.1 
mv | gy | | II 
1 作 下 载 的 文件 不 地 在 9 
Iternat 所 各 县 ， 
0 BE C3 


图 4.7 header0 函 数 实现 文件 下 载 


图 关键 技术 


通过 HTTP 方式 下 载 文件 ， 主 要 应 用 header0 函 数 。 

header0 函 数 属于 HTTP 函数 , 其 作用 是 以 HTTP 协议 将 HTML 文档 的 标 头 送 到 浏览 器 , 并 告诉 浏览 器 具体 
怎么 处 理 这 个 页 面 。header0 函 数 的 语法 如 下 : 

void header ( string string [. bool replace [. int http_response_code]] ) 

参数 说 明 : 

string: 发 送 的 标 头 。 

replace: 如 果 一 次 发 送 多 个 标 头 ， 对 于 相似 的 标 头 是 替换 还 是 添加 。 如 果 是 false， 则 强制 发 送 多 个 同类 型 
的 标 头 。 默 认 是 true， 即 替换 。 

http_response code: 强制 HITP 响应 为 指定 值 。 

通过 HTTP 下 载 的 代码 如 下 : 


header("Content-type: application/x-gzip"); 
header("Content-Disposition: attachment: filename= 文 件 名 "); 
header("Content-Description: PHP3 Generated Data"): > 


HTTP 标 头 有 很 多 ， 这 里 介绍 的 是 下 载 的 HITP 标 头 ， 其 代码 如 下 : 
header(Content-Disposition: attachment: filename="filename”™); 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 flename， 即 将 filename 替换 为 要 下 载 的 文件 。 
图 设计 过 程 


(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 创建 超 链接 ， 链 接 到 download.php 文件 ， 通 过 download.php 完 
成 文件 的 下 载 操作 。 在 index.php 文件 中 所 做 的 修改 如 下 : 
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<td width="245" height="100" align="center' valign="middle" bgcolor="#FOFOF0"><a href="download-<?php 


点 击 即 可 下 载 ! "><?php echo "<img src=\"$myrow[file_test]\" width=\ 


echo Smyrow[file_test]:?>.html" title=" 


"250\" height=\"100\" border=\"0\">"?></a></td> 


(2) 创建 download.php 文件 ， 应 用 header0 函 数 ， 实 现 文 件 的 下 载 ， 其 代码 如 下 : 


<?php 
header("Content-type: text/html: charset=UTF-8"); 
$path = $_GET[path]:; 
if(!empty($path) and !is_null($path)){ 
Sfilename=basename($path); 
Sfile=(@fopen($path,"r"); 
if(Sfile){ 
header("Content-type:application/octet-stream"); 
header("Accept-ranges:bytes"); 
header("Accept-length:" filesize(Spath)); 


header("Content-Disposition:attachment:filename=".$filename); 


echo fread(S$file,filesize(Spath)); 
felose($file); 
exit 

Jelse{ 


// 设 置 文件 编码 格式 

/获取 文件 路 径 

/ 济 断 变量 是 否 为 室 ， 是 否 为 NULL 
/获取 文件 名 


/输出 MIME 类 型 

/| 接受 的 范围 单位 

/文件 长 度 

// 缺 省 时 文件 保存 对 话 框 中 的 文件 名 称 
/ 读 取 文件 

1/ 关闭 文件 

/退出 


echo "<script>alert( 您 下 载 的 文件 不 存在 ! ); history.back0;</script>"; 


} 


} 
> 


力 秘笈 心 法 


心 法 领悟 229: header0 函 数 的 应 用 。 


通过 headerO 函 数 ， 不 但 可 以 实现 文件 的 下 载 ， 还 可 以 实现 以 下 3 个 功能 : 


(1) 重 定向 ， 这 是 最 常用 的 功能 。 
header("Location: http://www.mrbccd.com"); 


(2) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 


// 设 置 页 面 的 过 期 时 间 ( 用 格林 威 治 时 间 表 示 )。 


header("Expires: Mon, 08 Ju 2008 08:08:08 MT"); 
// 设 置 页 面 的 最 后 更 新 日 期 (用 格林 威 治 时 间 表 示 )， 使 浏览 器 获取 最 新 资料 


header("Last-Modified: " . gmdate("D, dM Y H:i:s") . "GMT"); 
header("Cache-Control: no-cache, must-revalidate"); 
header("Pragma: no-cache"); 

header("Content-type: application/file"); 
header("Content-Length: © 227685"); 
header("Accept-Ranges: bytes"); 

/ 缺 省 时 文件 保存 对 话 框 中 的 文件 名 称 


header("Content— Disposition: attachment: filename=$filename”); 


(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
header(HTTP/1.1 401 Unauthorized): 
header(status: 401 Unauthorized"): 


而 不 是 使 用 存在 于 客户 端的 缓存 。 


/控制 页 面 不 使 用 缓存 

/参数 与 以 前 的 服务 器 兼容 ) ， 即 兼容 HTTP1.0 协议 
/输出 MIME 类 型 

/文件 长 度 

/接受 的 范围 单位 


/实现 F 载 


43 文件 遍历 


力 实例 说 明 


在 开发 网 站 的 过 程 中 ， 很 多 的 服务 条 款 、 协 议 等 都 是 以 文本 文件 的 形式 存储 的 。 如 果 要 读 取 这 些 文件 中 的 
内 容 ， 就 需要 应 用 到 文件 系统 函数 。 在 本 实例 中 ， 将 介绍 如 何 通过 文件 系统 函数 读 取 整个 文件 的 内 容 ， 其 运行 


效果 如 图 4.8 所 示 。 
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€ 
个 
S 
人 


> 


大 连 参 展 工作 总 结 

一 立 大 连 立 行 * 乓 拥 良 多 ， 妈 或 此 行 作 如 下 总 车 = 

六 区 昌 向 守 ” 则 主 同 全 闫 不 足 ， 缮 舌 不 育 旭 ”流程 不 各 请 紫 ， 工 作 开 民 牛 没有 头 委 分 工 
(2) 产品 -宣传 片 设计 的 一 般 ， 役 有 达到 良好 的 宣传 效果 ;宣传 资料 几 于 是 役 有 ， 日 前 
的 宣传 宰 料 体现 不 出 产品 的 符 点 ， 不 移 栅 范 - 设 有 科 丢 性 ”让 人 无 从 下 于 ;数字 化 的 宣 
传 更 是 蜡 阵 唐 念 ， 商 有 一 个 完 杏 ， 铸 研 的 二 传 语 言 

(3) 展 旧 * 与 最 初 的 设计 效果 相关 共 所， 没有 体现 出 数字 化 的 用 会 

(4) 机 器 人 不 能 息 从 它 身上 直接 看 泌 与 我 们 的 广 曲 式 者 要 字 化 介 展 的 联系 

(5) 广 品 与 展 冲 、 机 雪人 的 联 夭 不 明星 ”无 泥 是 从 展 吝 、 还 是 机 器 人 身上 莉 不 侯 涉 而 单 
明了 的 体现 出 我 们 的 广 品 或 者 理念 ， 都 震 要 闲 我 们 的 由 课 坟 了 了 、 体 会 

(6) 体 登 中 心 * 体验 的 是 什么 了 

(1) 设 音 的 配备 、 甘 久 设备 的 迁 取 不 竺 语 娃 ， 送 篇 方 法 的 连天 也 不 女友 ' 不 移 统 一 

(5) 住 调 安 排 配 好 - 

感触 陆 深 = 

(1) 惠 立 大 局 的 兰芝 者 

(2) 总 菠 参 展 的 经 验 ， 制 走出 一 奉 合 理 的 驮 民 访 在 

(3) 合理 的 分 配 工作 ~ 

(4) 制 下 出 充 束 国人 公 司 二 传 坦 料 、 力 在 间 典 让 传 查 料 和 数字 化 友 下 方向 的 直 传 斑 料 “ 

关 澡 入 所 与 六 本 人 的 适用 必须 体现 出 公司 的 广 品 、 数字 售后 民 民 力 内 ， 党 到 让 人 一 日 了 
(5) 冶 理 的 实 诽 设备 的 配备 区 

(1) 提前 做 好 参展 人 员 的 吃 、 住 和 条 的 工作 
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图 4.8 读 取 文 本 文件 的 内 容 


力 关键 技术 


在 PHP 中 ， 读 取 整 个 文件 的 内 容 ， 有 3 个 函数 可 以 选择 : 

回 readfile0 函 数 

readfileO 函 数 读 取 一 个 文件 并 将 其 写 入 输出 缓冲 ， 成 功 ， 返 回 读 取 的 字 节 数 ， 失败， 返回 FALSE， 语 法 
Te 

参数 flename 指定 读 取 的 文件 名 称 ; 参数 use_include_path 控制 是 否 支持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设置 为 TRUE; 参数 context 是 PHP 5.0 的 新 增 内 容 。 


说 明 : 应 用 readfile0 函 数 时 ， 不 需要 打开 /关闭 文件 和 输出 语句 ， 直 接应 用 即 可 。 


file0 函 数 

file0 函 数 将 整个 文件 的 内 容 读 入 一 个 数组 中 。 成 功 ， 返 回 数组 ， 数 组 中 的 每 个 元 素 都 是 文件 中 对 应 的 一 行 ， 
包括 换行 符 在 内 ， 失 败 ， 返 回 FALSE。 语 法 如 下 : 

array file ( string filename [, int use_include_path [, resource context]] ) 

其 参数 与 readfile0 函 数 相 同 ， 唯 一 区 别 是 该 函数 的 返回 值 是 数组 。 

file_get_contents0 〇 函数 

file_get_contents0 函 数 将 文件 内 容 读 入 一 个 字符 串 。 如 果 有 offset 和 maxlen 参数 ,将 在 参数 offset 所 指定 的 
位 置 开始 读 取 长 度 为 maxlen 的 内 容 。 如 果 失 败 ， 返 回 FALSE。 语 法 如 下 : 

string file_get_contents ( string filename [. bool use_include path [, resource context [. int offset [. int maxlen]]]] ) 

参数 flename 指定 读 取 的 文件 名 称 ; 参数 use_include path 控制 是 否 支持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设 置 为 TRUE。 
图 设计 过 程 

(1) 创建 index.php 文件 。 


(2) 在 index.php 文件 中 分 别 应 用 file0 和 他 e_get_contents0 函 数 读 取 文 本 文件 中 的 内 容 ， 其 关键 代码 如 下 : 
<!-- ”使 用 鲁 e0 函 数 读 取 count.txt 文 件 的 内 容 。--> 


<?php 
Sarr = file('test1.txt); 
foreach ($arr as $value) { 

echo iconv("gb2312", "utf-8", $value) . "<br>"; 
} 


297 


PHP 开发 实战 1200 例 (第 I 卷 ) 


> 
<!-- 使 用 fle_get_contents0 函 数 读 取 count.txt 文件 的 内 容 -> 


<?php 

$str = file_get_contents('test2.txt); 
echo iconv("gb2312", “utf-8", $str); 
> 


图 秘笈 心 法 


心 法 领悟 230: 读 取 整 个 文件 的 特性 。 

在 通过 readfile0、fle0 和 fe_get_contents0 函 数 读 取 整 个 文件 中 的 内 容 时 ， 不 需要 通过 fopen0 函 数 打 开 文 
件 ， 也 不 需要 使 用 人 felose0 函 数 关 闭 文件 。 

但 是 , 在 读 取 一 个 字符 、 一 行 字符 和 任意 长 度 的 字符 串 时 ,必须 应 用 fopen0 函 数 打开 文件 后 才能 进行 读 取 ， 
在 读 取 完成 后 还 要 应 用 fclose0 函 数 关闭 文件 。 


高 级 | 


实例 231 趣味 指数 ， 请 请 诊 廊 家 


图 实例 说 明 


在 遍历 文件 中 的 内 容 时 ， 由 于 文件 内 容 很 多 ， 最 理想 的 方法 就 是 分 页 读 取 文 本 文件 中 的 内 容 。 本 实例 将 介 
绍 如 何 分 页 读 取 文 本 文件 中 的 数据 ， 其 运行 结果 如 图 4.9 所 示 。 
三 执 了 之 于 与 子供 龙 | 4 
大 着 何 示 ! Nn 
”i hn 
诗句 评价 


首页 上 一 页 下 一 页 尾 页 
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图 4.9 文本 文件 的 分 页 读 取 


力 关键 技术 

完成 超 长 文本 的 分 页 输出 需要 3 方面 的 技术 : 第 1 方面 ， 自 定义 函数 。 通 过 自 定义 函数 读 取 文本 文件 ， 可 
以 避免 中 文字 符 串 出 现 乱 码 ， 第 2 方面 ， 字 符 串 函数 。 需 要 通过 strlen0 函 数 计 算 字符 串 的 长 度 ， 通 过 substr0 
函数 对 字符 串 进行 截取 ; 第 3 方面 ， 文 件 系统 函数 。 通 过 fle_get contentsO0 函 数 读 取 文本 文件 中 的 数据 。 


自 定义 函数 msubstr0 的 语法 如 下 : 
/定义 一 个 用 于 截取 一 段 字符 串 的 函数 msubstr0 
function msubstr($str, $start, Slen){ /sstr 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，Slen 指 的 是 长 度 
Sstrlen=$start+S$len; /用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i=0:$i<S$strlen:Sit+){ // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
if(ord(substr($str.$i.1))>0xaO){ // 如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 则 表示 为 汉字 
Stmpstr.=substr($str, $1.2): // 每 次 取出 两 位 字符 赋 给 变量 $Stmpstr， 即 等 于 一 个 汉字 
Sit+; /变量 自 加 1 
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jelsef // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr. =substr(Sstr,$i.1); 
上 
} 
Tetum $tmpstr /输出 字符 串 
} 


图 设计 过 程 

(1) 创建 fnnction php 文件 ， 编 写 自 定义 函数 msubstr0， 完 成 对 文本 文件 的 截取 操作 。 

(2) 创建 index.php 文件 ， 首 先 通过 文件 系统 函数 fle_get_contents0 读 取 整 个 文件 的 内 容 ， 然 后 调用 自 定 
义 函数 和 字符 串 函数 完成 对 文件 的 截取 操作 ， 实 现 截取 后 内 容 的 分 页 输出 ， 其 关键 代码 如 下 : 

和 用 于 获取 js 文件 中 返回 的 分 页 结果 --> 


<table width="545" border="0" cellspacing="0" cellpadding="0"> 
<b> 


<td><?php 
include("function.php"); 
// 读 取 超 长 文本 中 的 数据 ， 实 现 超 长 文本 中 数据 的 分 页 显示 
这 $ GET[pageT{ 
$counter=file_ get_contents("data.txt"): 
Slength=strlen( $counter); 
$page count=ceil($length/850); 
$c=msubstr($counter,0,($_GET['page']-1)*850); 
$cl=msubstr($counter,0.$_GET['page']*850); 
echo substr($c1,strlen($c),strlen($c1)-strlen($c)); 
型 
<td> 
<t> 
<t> 
<td><table width="535" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<!-- 设 置 超 长 文本 分 页 显示 的 超级 连接 --> 
<td width="37%" align="center" valign="middle" bgcolor="#FFFFFF"> 内 容 &nbsp;<?php echo $page_count;?> 页 
&nbsp;&nbsp; 当 前 &nbsp; 第 <?php echo $_GET[page1];?> 页 </td> 
<td width="63%" height="28" align="center" valign="middle" bgcolor="#FFFFFF"><?php 
if(s_GET[page]'=D{ 


<!-- 调 用 no_refurbish_pagination 函数 ， 实 现 无 刷新 的 分 页 输出 -> 
<a href="#" onClick=Yretum no_refurbish pagination("index_ok.php?page=1")> 首 页 </a>&nbsp: <a href="#" 
‘onClick='retum no_refurbish_ pagination("index_ok.php?page=<?php echo $_GET[page]-1:?>")> 上 一 页 </a> 
<?php } 
这 $_GET[page]<$page_counb{ 


<a href="#" onClick=returmn no_refurbish pagination(index_ok .php?page=<?php echo $_GET[page]+1:?>")"> 下 一 
页 </a> <a href="#" onClick='retum no_refurbish pagination("index_ok .php?page=<?php echo $page_count:?>")> 尾 页 </a> 


> 


<?php 
} 
> 
<htd> 
</tr> 
‘</table></td> 
</t> 
</table> 


</div> 
(3) 创建 index_ok.php 文件 ， 实 现 数据 的 无 刷新 分 页 。index_ok.php 中 的 内 容 与 index.php 中 div 标签 
synopsis 的 内 容 相 同 。 
(4) 创建 js 脚本 文件 discuss_jsjs， 通 过 Ajax 实现 无 刷新 的 操作 。 
图 秘笈 心 法 


心 法 领悟 231: Ajax 无 刷新 分 页 。 
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在 本 实例 中 不 但 实现 了 文本 文件 内 容 的 分 页 输出 ， 而 且 是 无 刷新 分 页 输出 。 具 体操 作 通 过 js 脚本 文件 
discuss jsjs 和 index_ok.php 完成 。 
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实例 232 


力 实例 说 明 


为 了 便于 对 网 站 进行 管理 、 维 护 和 更 新 ， 应 该 设计 一 个 能 够 对 文件 进行 操作 的 模块 ， 实 现 对 文件 的 创建 、 
复制 、 移动 和 删除 等 操作 , 这 样 能 够 给 网 站 的 管理 工作 提供 很 大 的 方便 , 不 再 因为 要 修改 某 个 文件 而 登录 到 FTP 
中 、 通 过 下 载 或 上 传 实现 文件 的 更 新 ， 从 而 节省 很 多 时 间 。 运 行 本 实例 ， 实 现 对 指定 文件 的 创建 、 复 制 、 移 动 
和 删除 操作 。 只 要 在 文本 框 中 输入 要 复制 文件 的 路 径 和 名 称 ， 在 对 应 的 文本 框 中 输入 指定 文件 要 复制 到 的 具体 
文件 夹 的 路 径 和 名 称 〈 包 括 指定 文件 的 名 称 ) ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 ， 运 行 结果 如 图 4.10 所 示 。 


管理 系 综 
Syste 


欢迎 来 到 阴 日 x 体 管理 系统 I 


m 


0 : MR OAD Zuindex php 提交 
TvwwwMRO4AOTFmages | 
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图 4.10 文件 操作 汇总 


图 关键 技术 


本 实例 主要 应 用 fopen0、copy0、rename0 和 unlink04 个 函数 完成 文件 的 创建 、 复 制 、 移 动 和 删除 操作 。 
fopen0 函 数 用 于 打开 文件 或 者 URL， 其 语法 如 下 : 

int fopen(string filename, string mode); 

创建 文件 主要 应 用 fopen0 函 数 的 mode 参数 ，mode 参数 的 可 选 值 如 下 : 

'w' 写 入 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 零 。 如 果 文 件 不 存在 ， 则 进行 创建 。 

'w+' 读 写 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 零 。 如 果 文 件 不 存在 ， 则 进行 创建 。 
'a 写 入 方式 打开 ， 将 文件 指针 指向 文件 未 尾 。 如 果 文件 不 存在， 则 进行 创建 。 

'at' 读 写 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 


说 明 : 上 述 4 种 方式 都 可 以 完成 文件 的 创建 操作 ， 前 提 是 指定 路 径 下 不 存在 被 创建 的 文件 。 
copy0O 函 数 主要 用 于 复制 文件 ， 其 语法 如 下 : 


回回 回回 
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int copy(string source, string dest); 


本 函数 将 文件 从 source 复制 到 dest， 如 果 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 


Iename0 函 数 主要 用 于 文 4 


bool rename(string oldname.newname); 


命名 ， 其 语法 如 下 : 


本 函数 将 oldname 重 命 名 为 newname， 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 


该 文件 的 名 称 ， 即 可 实现 对 指定 文件 的 移动 操作 。 


unlinkO 函 数 主要 用 于 删除 文件 ， 其 语法 如 下 : 
bool unlink(string filename); 


上 -| 说 明 : enameO 函 数 不 但 可 以 给 文件 重 命名 ， 当 将 指定 的 文件 移动 到 另外 一 个 路 径 下 的 文件 夹 中 时 ， 不 改变 


本 函数 用 于 删除 文件 。 如 果 删 除 成 功 则 返回 tue， 和 否则 返回 false。 


图 设计 过 程 


(1) 创建 index.php 文件 。 首 先 ， 设 计 文 件 汇总 的 页 面 。 


然后 应 用 switchO 语 名 设计 一 个 简单 的 框架 ， 完 成 


复制 、 移 动 、 创 建 和 删除 操作 之 间 的 切换 。 最 后 ， 编 写 PHP 脚本 ， 根 据 表单 中 提交 的 数据 ， 执 行 不 同 的 文件 操 


作 ， 其 关键 代码 如 下 : 
<?php 
Switch ($ GET ['operate]) { 
case "found" : 
include ("found.php"); 
break; 


Case "copy" : 
include ("copy.php"); 
break: 


Case "move" ; 
include ("move.php"); 
break: 

case "delete" : 
include ("delete.php"); 
break: 


default : 
include ("copy.php"); 
} 
?> 


<?php 
让 ($_POST [Submit] 一 "复制 ") { 
$copy = iconv ( "utf-8", "gb2312", $_POST [copys]): 
$copys2 = iconv ( "utf-8", "gb2312". $_ POST ['copys2"] ); 
if (copy ( $copy, $copys2 )) { 

echo "<script>alert(' 复 制 成 功 !1);</script>"; 
}elsef 

echo "<script>alert( 复 制 失 败 !1);</script>"; 
} 


} 
/省 略 了 部 分 代码 
> 


(2) 分 别 创建 copy.php、delete.php、found.php 和 move.php 文件 ， 完 成 不 同 操作 的 执行 页 面 。copy.php 文 


件 的 代码 如 下 : 
<table width="466" height="112" border="0" cellpadding="0" cellspacing="0"> 
<form name="form1" method="post" action=""> 
<t> 
<td width="111" rowspan="2" align="center"> 复 制 文件 </td> 
<td width="67" align="right" valign="bottom">copy: </td> 
<td width="229" height="39" valign="bottom"><input name="copys" 
type="text" id="copys" size="22"></td> 
<td width="126" rowspan="2" align="left" valign="middle"><input 
type="submit" name="Submit' value=" 复 制 "></td> 
< 
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<b> 

<td align="right" valign="top">affix: </td> 

<td height="41" valign="top"><input name="copys2" type="text" 

id="copys2" size="22"></td> 

<t> 
<b> 

<td colspan="4" align="center"> 例 如 : F:\xampp\htdocs\IMR\05\012\test.txt</td> 
</t> 
</form> 
</table> 


图 秘笈 心 法 


心 法 领悟 232: 编码 格式 转换 的 必要 性 。 

在 应 用 文件 操作 函数 执行 文件 的 创建 、 移 动 、 复 制 和 删除 操作 时 ， 由 于 实例 的 页 面 编码 格式 是 utf-8， 所 以 
从 表单 中 获取 的 元 素 值 ,不 能 够 直接 应 用 到 文件 操作 函数 中 , 必须 对 其 进行 编码 转换 , 由 utf-8 编码 转换 为 gb2312 
编码 ， 和 否则 文件 操作 函数 不 能 够 正确 地 执行 。 


中 级 | 
趣味 指数 : 会 依依 家 | 


实例 233 


图 实例 说 明 


对 目录 、 文 件 的 操作 不 应 该 是 盲目 的 ， 应 该 首先 确定 其 是 否 存 在 ， 如 果 存 在 才能 够 对 它 执行 各 种 操作 ， 盏 
则 是 没有 任何 意义 的 。 相 反 ， 有 些 操作 必须 是 在 指定 的 目录 、 文 件 不 存在 的 情况 下 进行 的 。 此 时 必须 有 一 个 方 
法 能 够 对 目录 、 文 件 进行 定位 ， 确 定 它 是 否 存在 ， 这 就 是 本 实例 将 要 讲解 的 内 容 。 运 行 本 实例 ， 在 文本 框 中 输 
入 目录 、 文 件 的 完整 路 径 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.11 所 示 。 


文件 名 称 : [FwppSevwwwMROA4 有 本 


语 输 入 正确 的 目录 、 文 件 路 径 ? 


如 1 CopyRights © reserved 2010 言 林 省 明日 科技 有 限 公司 
图 4.11 目录 、 文 件 定位 器 
上 说 明 : 本 实例 实现 的 功能 虽然 非常 简单 ， 但 是 这 个 方法 在 很 多 程序 中 都 会 被 用 到 ， 只 是 表现 的 方式 不 同 。 


图 关键 技术 


PHP 中 判断 指定 的 目录 、 文 件 是 否 存在 ， 应 用 的 是 fie_exists0 函 数 ， 函 数 的 语法 如 下 : 


本 函数 用 来 检测 目录 、 文 件 是 否 存在 ， 如 果 存 在 返回 TRUE， 否 则 返回 FALSE。 
int file_exists(string filename); 


说 明 : 要 在 Windows 下 检查 网 络 中 的 共享 文件 应 该 使 用 //computemame/share/filename 或 者 \computername\ 
share\filename. 
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图 设计 过 程 


(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
(2) 添加 表单 ， 设 置 文本 框 ， 提 交 目 录 、 文 件 的 完整 路 径 ， 并 设置 提交 按钮 。 
(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 目录 、 文 件 路 径 。 首 先 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 
后 应 用 file_existsO 函 数 判断 指定 的 目录 、 文 件 是 否 存在 ， 其 关键 代码 如 下 : 

Taosr [file name] ="") { 

S$file name = iconv ( "utf-8", "gb2312", $_POST [file name]); 

if (file exists ( $file name )) { 

echo "<script>alert( 目 录 、 文 件 已 定位 ! "):</script>"; 
else 

: te 文件 不 存在 ! :</script>"; 

"<script>alert( 请 输入 正确 的 目录 、 文 件 路 径 ! ");</script>"; 


} 
> 


也 笈 心 法 


心 法 领悟 233: utf-8 编码 格式 对 中 文字 符 串 的 影响 。 

在 本 实例 中 , 由 于 使 用 的 是 utf-8 编码 格式 , 因此 当 提 交 的 目录 、 文件 路 径 中 存在 中 文字 符 串 时 ,file_existsO 
函数 就 不 能 够 正确 地 判断 目录 、 文 件 是 否 存 在 。 只 有 将 utf-8 编码 格式 的 元 素 值 转换 为 gb2312 编码 格式 之 后 ， 
file_exists0) 函 数 才能 对 中 文字 符 串 的 目录 、 文 件 路 径 作出 正确 的 判断 。 


图 实例 说 明 


在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 经 常会 修改 文件 的 名 称 。 本 实例 将 介绍 一 种 修改 文件 名 称 的 方法 。 运 
行 本 实例 ， 在 “原文 件 名 称 ” 文 本 框 中 输入 原始 文件 的 存储 路 径 和 文件 名 ， 在 新 文件 名 称 文本 框 中 输入 新 文件 
的 路 径 和 文件 名 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.12 所 示 。 


| 


[FwppSewwwwMRO4O13NMAGESS 
| 
新 文件 名 称 : ppSewwwwMRO4O13UMAGESVesttbd 


修 故 成 功 ! 


1 copyaiehts e reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.12 修改 文件 名 


图 关键 技术 


文件 重 命名 应 用 的 是 rename0 函 数 ， 不 过 首先 要 应 用 名 e_exists0 函 数 判 断 该 文件 是 否 存在 ， 如 果 存 在 则 应 
用 rename0 函 数 对 该 文件 进行 重 命名 ， 否 则 给 出 提示 信息 。 
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图 设计 过 程 

(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 

(2) 添加 表单 ， 设 置 两 个 文本 框 ， 提 交 文 件 的 原始 名 称 和 新 名 称 ， 并 设置 提交 按钮 。 

(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 元 素 值 。 由 于 网 页 使 用 的 是 utf-8 编码 ， 所 以 为 了 避免 在 获取 中 文 
字符 串 时 出 现 乱 码 ， 应 先 用 iconv0O 函 数 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 后 应 用 fle_existsO 函 数 判断 指 
定 的 文件 是 否 存在 ， 如 果 存 在 则 应 用 renameO 函 数 对 其 进行 重新 命名 ， 其 关键 代码 如 下 : 


<?php 
过 ($_POST['Submit] 一 "提交 ") { 


S$old_name=iconv("utf-8","gb2312",$_POST['old_name"]): /获取 表单 元 素 ， 并 进行 编码 格式 转换 
S$new_name=iconv("utf-8","gb2312"$_POST[mew_name]): /获取 表单 元 素 ， 并 进行 编码 格式 转换 
if (file_exists ( $old_name )) { /1/ 判 断 文 件 是 否 存在 
if (rename ( $old_name, $new_name )) { // 把 原文 件 重新 命名 
echo "修改 成 功 "; 
} else t 


print $ POST['old_name'] . "文件 不 存在 !<br>"; 
}; 


3 
> 


也 笈 心 法 

心 法 领悟 234: iconv0 函 数 在 转 码 过 程 中 的 重要 性 。 

如 果 程序 设计 时 应 用 的 是 utf 8 编码 ,那么 就 有 必要 了 解 iconv0 函 数 。 因 为 操作 系统 默认 使 用 的 是 简体 中 文 
(gb2312 编码 或 者 gbk 编码 ) ， 所 以 在 将 utf 8 编码 格式 的 数据 应 用 到 默认 为 gb2312 编码 的 程序 中 时 ， 难 免 会 
执行 失败 ， 特 别 是 涉及 到 中 文字 符 串 时 。 例 如 ， 在 本 实例 中 ， 如 果 直接 将 获取 的 表单 元 素 值 应 用 到 file_exists() 
函数 或 者 rename0 函 数 中 ， 就 会 出 现 乱 码 。 


中 级 
趣味 指数 : 会 依依 家 | 


力 实例 说 明 


如 果 说 判断 目录 、 文 件 是 否 存在 是 对 目录 、 文 件 进行 操作 的 前 提 条 件 ， 那 么 获取 文件 属性 则 是 对 文件 进行 
操作 的 必要 条 件 。 因 为 在 执行 一 些 特殊 的 操作 之 前 ， 必 须 对 文件 的 类 型 、 大 小 或 者 修改 时 间 进 行 判断 。 在 本 实 
例 中 ， 将 介绍 如 何 获取 文件 的 类 型 、 大 小 和 修改 时 间 。 运 行 本 实例 ， 在 文本 框 中 输入 正确 的 目录 或 者 文件 的 路 
径 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.13 所 示 。 


文件 各: 后 WppSevwwwMROAD15index php 。 切 殉 
请 输入 正确 的 目录 、 文 件 路 径 ? 


文件 类 型 : 
文件 大 小 : 2403 子 节 
修改 时 间 : 2010.07.03052456 


人 1 CopyRiehts © reserved 2010 言 林 省 明日 科技 有 限 公司 


图 4.13 文件 属性 分 析 
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力 关键 技术 


PHP 中 ,获取 文件 类 型 使 用 filetype0 函 数 ,获取 文件 大 小 使 用 flesizeO 函 数 , 而 获取 修改 时 间 使 用 flemtimeO 
函数 。 

filetype0 函 数 ， 用 于 获取 文件 类 型 ， 其 语法 如 下 : 

string filetype ( string filename ) 

该 函数 返回 文件 的 类 型 ， 类 型 值 包括 fifo、char、dir、block、link、file 和 unknown。 

如 果 出 错 则 返回 FALSE。 

filesize0 函 数 ， 用 于 获取 文件 大 小 ， 其 语法 如 下 : 


int filesize ( string filename ) 
该 函数 返回 文件 大 小 的 字 节 数 ， 如 果 出 错 返回 FALSE 在 错误 报告 级 别 为 E_ WARNING 的 情况 下 ) 。 
[ED 说 明 : 因为 PHP 的 整数 类 型 是 有 符号 的 ， 并 且 大 多 数 平台 使 用 32 位 整数 ，filesize0 函数 在 碰 到 大 于 2GB 

的 文件 时 可 能 会 返回 非 预期 的 结果 。 对 于 2GB~4GB 之 间 的 文件 通常 可 以 使 用 sprintf"%u"， 
filesize($file)) 来 克服 此 问题 。 

filemtime0) 函 数 ， 用 于 获取 文件 修改 时 间 ， 其 语法 如 下 : 

int filemtime ( string filename ) 

该 函数 返回 文件 上 次 被 修改 的 时 间 ， 出 错时 返回 FALSE。 时 间 以 UNIX 时 间 惟 的 方式 返回 ， 可 用 于 date()。 


设计 过 程 


(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 

(2) 添加 表单 ， 设 置 目 录 、 文 件 提交 的 文本 框 ， 提 交 目 录 或 者 文件 的 路 径 ， 并 设置 提交 按钮 。 

(3) 编写 PHP 脚本 , 获取 表单 中 提交 的 元 素 值 。 首先 , 判断 提交 的 值 是 否 为 空 , 如 果 不 为 空 , 则 应 用 iconvO 
函数 对 字符 串 的 编码 格式 进行 转换 。 然 后 ， 应 用 file_exists0 函 数 判断 指定 的 目录 或 者 文件 是 否 存在 ， 如 果 存 在 
则 获取 目录 或 者 文件 的 类 型 、 大 小 以 及 修改 时 间 ， 其 关键 代码 如 下 : 


<?php 
if($_POST ['file_name] (="") { 1/ 判断 表单 提交 的 值 是 否 为 空 

$file_name = iconv ( "utf-8", "gb2312", $_POST ['file_ name'] ): // 完 成 编码 格式 的 转换 

if (file_exists ( $file name )) { / 漳 断 目录 或 者 文件 是 否 存在 
Sfile type = filetype ( Sfile 1 name ); /获取 文件 类 型 
echo "<br> 文 件 类 型 ，". $file type . "<br>"; 
这 (Sfile type ‘="dir") { 1/ 判断 如 果 不 是 目录 

Sfile size= filesize ( Sfile_name ): / 苇 取 文件 的 大 小 


echo "文件 大 小 : ". Sfile size ." 字 逢 "br>"; 
} 


Sfile_mtime = filemtime ( $file name ); /获取 目录 或 者 文件 的 修改 时 间 
echo "修改 时 间 : " . date ( "Y-m-d H:i:s", $file_mtime ); /对 返回 的 时 间 蕉 进行 格式 化 输出 
}else{ 
echo "<script>alert(' 目 录 、 文 件 不 存在 ! :</script>"; 
} else { 
echo "<script>alert( 请 输入 正确 的 目录 、 文 件 路 径 ! );</script>"; 
| 
> 
图 秘笈 心 法 


心 法 领悟 235: 获取 文件 的 其 他 信息 。 

在 PHP 内 置 的 文件 系统 操作 函数 中 ， 不 仅 可 以 获取 文件 的 类 型 、 大 小 和 修改 时 间 ， 还 可 以 获取 文件 的 上 次 
访问 时 间 (fileatime0) 、inode 修改 时 间 (filectime0) 、 文 件 的 组 (filegroupO) 、 文 件 的 所 有 者 〈fileownerO) 、 
和 文件 的 权限 〈flepermsO) 等 
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高 级 | 


实例 236 


图 实例 说 明 


在 开发 程序 的 过 程 中 ， 很 多 时 候 都 需要 获取 到 文件 的 后 绥 名 ， 并 根据 后 绥 名 作出 一 些 判断 。 那 么 如 何 才能 
获取 文件 的 后 绷 名 呢 ? 在 本 实例 中 将 对 这 个 问题 进行 解答 。 运 行 本 实例 ， 将 检测 表单 中 提交 文件 的 后 缀 名 ， 并 
根据 后 级 名 称 ， 作 出 相应 的 判断 ， 其 运行 结果 如 图 4.14 所 示 。 


© 一 个 慌 TA 


选择 上 传 文件 ; [C:\Documents and Settin 让 


文件 区 型 : chza 上 传 成 功 ， 大 小 为 : 153557 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 4.14 上 传 文件 类 型 检测 


图 关键 技术 


在 本 实例 中 应 用 move_uploaded_file0 函 数 实现 文件 上 传 的 操作 ， 并 根据 文件 的 后 级 名 进行 判断 ， 将 不 同类 
型 的 文件 存储 在 不 同 的 服务 器 文件 夹 下 。 

获取 上 传 文件 后 缀 名 时 ， 首 先 ， 应 用 $_FILES 全 局 变量 获取 上 传 文件 的 名 称 。 然 后 ， 应 用 strstr0 函 数 对 
上 传 文件 的 名 称 进 行 截取 ， 截 取 字 符 串 中 “.” 后 的 所 有 字符 串 。 最 后 ， 应 用 strtolower0 函 数 将 字符 串 转换 成 
小 写 。 

strstr0 函 数 , 用 于 获取 一 个 指定 字符 串 在 另 一 个 字符 串 中 首次 出 现 的 位 置 到 后 者 末尾 的 子 字符 串 ， 语 法 
Tg 
参数 说 明 : 
Haystack: 必要 人 参数， 指定 从 哪个 字符 串 中 进行 搜索 。 
Needle: 必要 参数 ， 指 定 搜索 的 对 象 。 如 果 该 参数 是 一 个 数值 ， 那 么 将 搜索 与 这 个 数值 的 ASCII 值 相 匹 
配 的 字符 。 如 果 执 行 成 功 ， 则 返回 剩余 字符 串 〈 存 在 相 匹 配 的 字符 ) ;如 果 没 有 找到 相 匹配 的 字符 ， 则 返回 
FALSE。 


说 明 : 有 关 文件 上 传 技术 的 讲解 请 参考 本 章 实例 227， 这 里 不 再 葡 述 。 
图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 添加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 ， 设 置 enctype="multipartform-data"， 将 数据 提 
交 到 本 页 。 

(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 。 

(4) 应 用 is_dir0 函 数 判断 指定 的 服务 器 文件 夹 是 否 存在 ， 如 不 存在 则 应 用 mkdir0 函 数 创 建文 件 夹 。 
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(5) 应 用 is_uploaded file0 函 数 判断 文件 是 否 是 HIPP POST 上 传 。 
(6) 获取 上 传 文件 名 称 的 后 缀 名 ， 根 据 后 绥 名 的 不 同 ， 定 义 不 同 的 存储 路 径 。 
(7) 应 用 move_uploaded file0 函 数 执行 文件 上 传 的 操作 。 


index.php 文件 的 关键 代码 如 下 : 
<?php 
if(! empty ( $_FILES [up_picture] [name] )) { / 济 断 上 传 内 容 是 否 为 空 
ff($_FILES [up_picture] [emror]> 0) { /判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错 误 :"; 
switch ($_FILES [up_picture] [error) { 
case 1 : 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 
case3 : 
echo "上 传 文件 不 全 "; 
break; 
Case 4: 
echo "没有 上 传 文件 "; 
break: 
} 
和 
}else{ 
if(!is_dir ("./txt/" )) { /1/ 判 断 指定 目录 是 否 存在 
mkdir ( "./txt/" ); /创建 目录 
} 
if(!is dir ("/pic/") { // 判 断 指定 目录 是 否 存在 
mkdir ( "./pic/" ); /创建 目录 
} 
if(!is dir("/fla”" )) { /判断 指定 目录 是 否 存 在 
mkdir "nan ): 1/ 创建 目录 
} 
if (is_uploaded file ( $_FILES [up_picture] [tmp_name’] )) { /判断 文件 是 否 是 HTPP POST 上 传 
Stype = $_FILES [up_picture] [name’]:; /获取 上 传 文件 的 名 称 
Stypes = strtolower ( strstr ( $type ) ); /获取 上 传 文件 的 后 级 
if ($types — ".txt" || $tyles — ".doc") { 
Spath ="/txt/ . time 0 . strstr ( $_FILES [up_picture] [name].…): /定义 上 传 文件 名 称 和 存储 位 置 
} elseif ($types 一 "jpg" | $tyles 一 "gif | Styles 一 "bmp"){ 
S$path = '/pic/ . time 0 . strstr ( $_FILES [up_picture] [name].…): /定义 上 传 文件 名 称 和 存储 位 置 
}else{ 
Spath ="./fla/’ . time 0 . strstr ( $_FILES [up_picture] [mame].，…): /定义 上 传 文件 名 称 和 存储 位 置 
} 
if(! move_uploaded file ( $_FILES [up_picture] [tmp_name], $path )) { /执行 上 传 操作 
echo "上 传 失败 1 "; 
}elsef{ 


echo "文件 类 型 : ". $types . ”上传 成 功 ， 大 小 为 :" . $_FILES [up_picture] [size]; 
} 
} else{ 
echo "上 传 文件 ，" . $_FILES [up_pictute] [name] . "不 合法 ! "; 
} 
> 


图 秘笈 心 法 
心 法 领悟 236: 文件 类 型 检测 的 妙用 。 


文件 后 级 名 的 获取 可 以 应 用 到 很 多 地 方 ， 最 为 常用 的 就 是 通过 它 来 控制 上 传 文件 的 类 型 ， 另 外 在 文件 的 读 
取 中 ， 用 于 判断 哪些 文件 可 以 读 取 ， 哪 些 不 可 以 。 
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实例 
实例 237 2 趣味 指数 : 便便 站 
图 实例 说 明 


文件 权限 的 判断 是 一 个 非常 重要 的 功能 ， 如 果 文 件 没有 读 、 写 的 权限 ， 那 么 就 不 能 对 其 进行 任何 操作 。 本 
实例 将 介绍 如 何 判断 文件 的 权限 。 运 行 本 实例 ， 通 过 文本 框 提交 文件 路 径 ， 向 指定 的 文件 中 写 入 数据 ， 如 果 文 
件 具 备 写 的 权限 ， 则 可 以 实现 数据 的 写 入 ， 和 否则 将 提示 文件 不 具备 写 入 的 权限 ， 运 行 结果 如 图 4.15 所 示 。 


ee 


a 


>、 
欢迎 采 到 了 明日 芭 件 管理 系统 


mm 


文件 名 称 : [wppSewwwwMRO4O15desttbd 提交 


请 输入 正确 的 文件 ( 例如 : FIAPPServrwwIMRIO401gtest txt ) 


陀 忆 不 惊 ,看 原 前 花 开花 陪 ; a 
文件 内 容 : | 去 留 无 意 , 望 天 上 云 息 云 舒 - 
习 


和 1 CopyRights © reservwd 2010 吉林 省 明日 科技 有 限 公司 


图 4.15 判断 文件 的 权限 


力 关键 技术 


判断 文件 是 否 具备 读 权限 应 用 的 是 is_readable0 函 数 ， 判 断 文件 是 否 具备 写 权 限 应 用 的 是 is_writable0 函 数 。 


is_readable0 函 数 ， 判 断 指 定 文件 是 否 可 读 ， 语 法 如 下 : 
boolis readable ( string filename ) 


如 果 文件 存在 并 且 可 读 则 返回 TRUE。 


is_writable0 函 数 ， 判 断 指定 文件 是 否 可 写 ， 语 法 如 下 : 
bool is_writable ( string filename ) 


如 果 文 件 存在 并 且 可 写 则 返回 TRUE。 参 数 filename 可 以 是 一 个 允许 进行 是 否 可 写 检查 的 目录 名 。 
< 注意 : PHP 也 许 只 能 以 运行 webserver 的 用 户 名 (通常 为 mobody' ) 来 访问 文件 。 不计 入 安全 模式 的 限制 。 


对 于 文件 权限 的 判断 ， 是 对 文件 进行 操作 的 前 提 ， 特 别 是 在 执行 文件 的 读 取 、 写 入 、 重 命名 等 操作 时 ， 如 
果 文 件 不 具备 读 、 写 的 权限 ， 那 么 这 些 操作 是 没有 任何 意义 的 。 

图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 添加 表单 ， 设 置 文 本 框 ， 提 交 指 定 文件 ， 设 置 文 件 域 ， 提 交 写 入 文件 中 的 数据 ， 设 置 提交 按钮 ， 使 用 
POST 方法 ， 将 数据 提交 到 本 页 。 

(3) 通过 $_ POST[] 方 法 获取 表单 提交 的 文件 路 径 和 文件 内 容 ， 并 通过 iconv0 函 数 对 获取 的 数据 进行 编码 
转换 。 首 先 ， 判 断 指 定 的 文件 是 否 存在 。 然 后 ， 判 断 指定 的 文件 是 否 具备 写 的 权限 ， 如 果 具 备 ， 则 将 表单 提交 
的 文件 内 容 写 入 到 文件 中 。 最 后 ， 关 闭 打开 的 文件 ， 给 出 提示 信息 。index.php 的 关键 代码 如 下 : 

if($_POST [file name] = mw&&is file (iconv ("utf-8", "gb2312", $ POST [file name])) 一 tme) { -= /判断 文 件 是 否 存在 

Sfile name = iconv ( "utf-8". "gb2312", $ POST [file name] ): // 编 码 转换 


Sfile content=iconv ("utf-8", "gb2312", $ POST [file content] );: 
证 (file exists ( $file name )) { 


第 4 章 文件 操作 


if(is_writable ( $file name )) { /1/ 判 断 文 件 是 否 具备 写 的 权限 
Sfp =fopen ( $file name, "w+" ): /打开 指定 的 文件 
证 Ce (Stp, $file_content )) { /| 执行 写 入 的 操作 
echo "<script>alert( 文 件 写 入 成 功 "):</script>"; 
}elsef 
echo "<script>alert( 文 件 写 入 失败 !);</script>"; 
} 
felose ( $fp ); /关闭 文件 
} else if (is readable ( $file name )) { /1/ 判 断 文件 是 否 具备 读 的 权限 
echo "<script>alert( 文 件 只 具备 读 权限 !");</script>"; 
}elsef 
echo "<script>alert( 文 件 不 具备 读 、 写 权限 !);</script>"; 
} 
}else{ 
echo "<script>alert( 文 件 不 存在 ! ");</script>"; 
} 
yelse { 
echo "<script>alert( 请 输入 正确 的 文件 路 径 ! :</script>"; 
’ 
> 
秘笈 心 法 


心 法 领悟 237: 通过 filepermsO 函 数 取得 文件 的 权限 。 
本 实例 中 介绍 的 是 通过 is_readable0 和 is_writable0 函 数 来 判断 文件 是 否 具有 读 、 写 的 权限 。 在 文件 系统 的 
函数 中 还 可 以 通过 flepermsO 函 数 取得 文件 的 权限 ， 其 返回 值 是 一 个 int 型 的 字符 串 。 
dike ~ 


力 实例 说 明 


在 网 站 开发 的 过 程 中 ， 经 常会 创建 注册 服务 条 款 或 者 会 员 须 知之 类 的 文件 。 处 理 此 类 文件 最 直接 的 方法 是 
将 其 生成 一 个 独立 的 页 面 ， ni tt 独立 的 文本 文件 中 ， 从 文本 文件 中 读 取 这 些 服务 条 款 ， 
这 样 不 占用 数据 库 的 空间 ， 而 且 不 占用 过 多 的 页 面 。 运 行 本 实例 ， 实 现 一 个 用 户 注册 的 功能 ， 并 从 文本 文件 中 
读 取 服 务 条 款 ， 运 行 结果 如 图 4.16 所 示 。 


卫 卫 因 从 给 生 全 能 问 典 皮 务 社区 国 时 时 是 时 时 | 
登录 名 : 


Emil: 


Pankaihual103@sina com 。 


联系 电话 : 迎 念 注 册 为 明日 编程 词典 服务 网 用 户 : 习 
站 放生 如 本 宙 拱 服 和 并 村 要务 社 积 申 ; 
ee -3 音字 中 国有 的 法 人 和 法 检 。 不 人 利用 二， 


( 含 我 已 阅读 条 款 ,确认 注册 ) 
下 )】 1999-2009 吉 林 省 明日 科技 有 限 公司 


图 4.16 从 文本 文件 中 读 取 注册 服务 条 款 
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图 关键 技术 


从 文本 文件 中 读 取 注册 服务 器 条 款 ， 可 以 分 为 两 个 部 分 : 第 一 部 分 是 表单 中 文件 域 的 创建 ， 第 二 部 分 是 应 
用 文件 系统 函数 读 取 、 输 出 指定 文本 文件 中 的 数据 。 

这 里 应 用 文件 系统 中 的 file0 函 数 读 取 文本 文件 中 的 数据 ， 有 关 文本 文件 中 数据 的 读 取 可 以 参考 4.3 节 中 的 
内 容 ， 这 里 不 再 歼 述 。 
图 设计 过 程 

(1) 创建 index.php 文件 。 

首先 ， 设 计 用 户 注册 页 面 。 然 后 ， 添 加 用 户 注册 的 表单 及 表单 元 素 ， 将 表单 元 素 的 值 提交 到 index_ok.php 
页 。 接 着 ， 编 辑 JavaScript 脚本 ， 通 过 chkreginfo0 方 法 对 表单 元 素 的 值 进行 判断 。 

最 后 ， 在 文本 域 中 编写 PHP 脚本 ， 通 过 file0 函 数 读 取 指定 文本 文件 中 的 数据 ， 通 过 foreachO 语 句 循环 输出 
注册 服务 条 款 ， 其 关键 代码 如 下 : 

<textarea name="register' cols="40" Tows="5r id="register"> 

人 
foreach ( Sarras Svalue ) { 
echo iconv ( "gb2312", "utf-8", $value ); 

必 

/textarea> 

(2) 创建 index_ok.php 文件 ， 通 过 $_POST[] 方 法 获取 表单 中 提交 的 数据 ， 输 出 用 户 的 注册 信息 。 

(3) 在 根 目录 下 创建 js 脚本 文件 夹 ， 编 写 checkjs 脚本 文件 ， 完 成 对 表单 元 素 值 的 判断 。 

秘笈 心 法 

心 法 领悟 238: 读 取 文本 文件 中 数据 时 函数 的 选择 。 

在 文件 系统 函数 中 ， 有 多 个 可 以 读 取 文本 文件 中 数据 的 函数 ， 为 了 使 读 取 到 的 数据 输出 时 条 理 更 加 清晰 ， 
建议 使 用 血 e0 函 数 ， 因 为 该 函数 将 读 取 到 的 数据 写 入 一 个 数组 中 ， 该 数组 中 的 每 个 元 素 是 文件 中 对 应 的 一 行 ， 
这 样 在 通过 foreahO 语 句 输出 数组 中 元 素 时 ， 是 按照 原文 件 中 的 行进 行 输出 的 ， 确 保 了 内 容 输出 的 条 理性 。 


趣味 指数 ， 傅 户 育 祖 安 


可 


力 实例 说 明 


网 站 的 计数 器 对 于 网 站 管理 者 来 说 是 一 个 非常 值得 关注 的 部 分 ， 它 记录 了 网 站 被 访问 的 次 数 ， 客 观 地 反映 
了 网 站 受 欢 迎 的 程度 。 而 文本 计数 器 是 最 简单 的 一 种 ， 它 将 数据 存储 于 文本 文件 中 。 在 本 实例 中 ， 将 介绍 这 种 
文本 计数 器 的 实现 方法 ， 并 且 将 重点 阐述 如 何 屏 项 网 页 刷新 对 计数 器 的 影响 。 运 行 本 实例 ， 将 输出 如 图 4.17 所 
示 的 内 容 。 


最 新 动态 。 。 此 时 是 : 2010 年 月 6 日 16:33:51 ”您 是 本 网 站 第 1800008 位 访客 ? 
图 4.17 可 以 屏蔽 刷新 功能 的 文本 计数 器 
此 时 ， 无 论 如何 刷 新 当前 页 面 ， 计 数 器 统计 的 值 都 不 会 再 发 生变 化 ， 除 非 关闭 此 页 面 ， 重 新 打开 。 
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力 关键 技术 


文本 计数 器 的 设计 思路 如 下 : 首先 ， 判 断 文本 文件 是 否 存 在 ， 如 不 存在 则 打开 失败 ; 如 打开 成 功 则 继续 执 
行 并 读 取 文 件 中 的 数据 ， 将 计数 器 增加 1。 然 后 ， 以 写 的 方式 重新 打开 文件 ， 把 新 的 统计 数据 写 入 文件 后 ， 关 
闭 文 件 。 最 后 ， 重 新 打开 文件 ， 读 取 并 输出 文件 中 的 数据 。 

操作 流程 如 图 4.18 所 示 。 


判断 文件 读 取 文 
多 是 否 存在 | 打开 文 | 本 文件 
回 本 文件 


图 4.18 文本 计数 器 的 操作 流程 


按照 这 个 原理 设计 的 计数 器 ， 当 刷新 页 面 时 计数 器 的 值 也 会 增加 ， 那 么 这 个 计数 器 就 没有 任何 意义 。 所 以 
要 想 这 个 计数 器 有 意义 ， 必 须 屏 蔽 页 面 刷 新 对 计数 器 的 影响 。 
这 里 通过 SESSION 来 实现 这 个 功能 ， 其 原理 如 图 4.19 所 示 。 


SESSION 变量 
重新 输出 将 新 数据 加 入 
网 站 访问 量 文本 文件 中 


4.19 网 站 计数 器 的 设计 原理 


图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 设 计 网 页 页 面 。 然 后 ， 初 始 化 SESSION 变量 。 接 着 ,编写 PHP 脚本 ， 
通过 文件 系统 函数 完成 网 站 访问 量 的 统计 ， 通 过 SESSION 屏蔽 网 页 刷新 对 计数 器 的 影响 。 最后, 输出 网 站 的 访 
问 量 和 当前 时 间 ， 其 关键 代码 如 下 : 


<?php 
session start |); /初始 化 一 个 session 变量 
> 
<?php 
/使 用 文本 存储 数据 
if($_SESSION [temp] — "") { // 判 断 $_SESSION[temp] 一 "的 值 是 否 为 空 ， 其 中 的 temp 为 自 定义 的 变量 
if ($fp = fopen ( "counter.txt", "r" )) — false) { 
echo "打开 文件 失败 !"; 
} else { 
Scounter = feets ( $fp. 1024 ); // 读 取 文件 中 数据 
felose ( $ftp ): 1 关闭 文本 文件 
$counter ++; /计数 器 增加 1 
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$fp = fopen ( "counter.txt", "w" ); /以 写 的 方式 打开 文本 文件 
fputs ( $fp, $counter ); // 将 新 的 统计 数据 增加 1 
felose ( $ 印 ): /关闭 文件 
3 
$_SESSION [temp] = 1; /1/ 计 数 器 的 值 增加 后 ， 为 $_SESSION[temp] 赋 值 1 
} 
/从 文本 文件 中 读 取 统计 数据 
证 (($ 印 = fopen ( "counter.txt", "r" )) — false) { 
echo "打开 文件 失败 !"; 
Yelse{ 
$counter = fgets ( $fp, 1024 ); /1/ 读 取 文 本 文件 的 数据 
fclose ( $fp ); 
} 
> 
(2) 在 实例 根 目录 下 创建 counter.txt 文本 文件 ， 用 于 存储 网 站 的 访问 量 。 
秘笈 心 法 


心 法 领悟 239: SESSION 防止 重复 计数 的 原理 解析 。 
首先 ， 在 网 页 被 访问 时 ， 初 始 化 一 个 SESSION 变量 ， 并 赋 给 其 一 个 空 值 。 然 后 ， 判 断 SESSION 变量 的 值 


是 否 为 室 ， 如 果 为 空 ， 则 将 计数 器 的 值 增加 1， 并 且 为 SESSION 变量 赋值 为 1。 此 时 ， 在 当前 页 中 ，SESSION 
变量 的 值 已 经 不 为 室 ， 无 论 如 何 刷新 ，SESSION 变量 的 值 都 不 会 改变 ， 所 以 计数 器 的 值 也 不 会 增加 。 


图 实例 说 明 


在 网 站 的 管理 系统 中 ， 有 时 需要 查看 某 个 文件 是 否 被 修改 过 、 在 什么 时 间 被 修改 的 、 最 后 的 修改 时 间 是 什 
么 时 候 ， 本 实例 就 可 以 实现 这 个 功能 ， 对 表单 中 提交 的 文件 进行 判断 ， 检 测 出 修改 时 间 ， 其 运行 结果 如 图 4.20 
所 示 。 


判断 文件 是 否 补 改动 
nm Be Er 


文惠 名 称 :FlippServinnwIMRW 


最 后 体 改 时 间 


图 4.20 检测 文件 是 否 被 修改 


图 关键 技术 


本 实例 主要 应 用 包 ectime0 和 flemtime0 函 数 ， 检 测 文件 的 incode 最 后 改变 时 间 和 最 后 的 修改 时 间 ， 并 应 用 
dateO0 函 数 对 检测 返回 的 时 间 惟 进行 格式 化 。 

filectime0 函 数 ， 返 回 指定 文件 filename 的 inode 最 后 改变 时 间 ， 语 法 如 下 : 

int filectime(string filename); 

成 功 则 返回 UNIX 时 间 惟 ， 和 否则 返回 FALSE。 

名 emtimeO 函 数 ， 返 回 指定 文件 包 ename 的 最 后 修改 时 间 ， 语 法 如 下 : 

int filemtime(string filename): 
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成 功 则 返回 UNIX 时 间 惟 ， 和 否则 返回 FALSE。 
图 设计 过 程 
首先 ， 设 计 网 页 页 面 。 然 后 ， 创 建 一 个 表单 ， 通 过 文件 域 提交 要 判断 的 文件 。 接 着 ， 获 取 表 单 中 提交 的 文 


件 路 径 ， 应 用 flectime0 和 血 emtime0 函 数 对 提交 的 文件 进行 检测 。 最 后 ， 输 出 检测 结果 。 
index.php 文件 的 关键 代码 如 下 : 


<?php 

Sfile =iconv ( "utf-8", "gb2312".S$_ POST ['files] ); // 实 现 编码 格式 的 转换 

if (file_exists ( $file )) { 1/ 判断 文件 是 否 存在 
S$change_time = filectime ( $file ); /获取 文件 的 最 后 incode 时 间 
Stime = date ( "Y-m-d hti:s", $change time ); /时 间 截 的 格式 化 
Slast_time = filemtime ( $file ); /获取 文件 的 最 后 修改 时 间 
Stimes = date ( "Y-m-d hii:s", $last_time ); /时 间 截 的 格式 化 

yelse { 
Sresult = "该 文件 不 存在 !"; 

> 

秘笈 心 法 


心 法 领悟 240: 获取 文件 的 最 后 访问 时 间 。 
通过 文件 系统 函数 不 但 可 以 获取 文件 的 最 后 修改 时 间 ， 而 且 可 以 获取 文件 的 最 后 访问 时 间 ， 其 应 用 的 是 
fileatime() 函 数 。 


实例 241 趣味 指数 : We 


实例 说 明 


应 用 POST 方法 上 传 文件 时 ， 需 要 将 上 传 文件 保存 到 服务 器 指定 的 目录 中 ， 这 时 可 能 会 出 现 因 名 称 相同 而 
文件 相互 替换 的 情况 。 为 了 解决 上 述 问 题 ， 可 以 应 用 basename0 函 数 和 随机 函数 mt_rand0 对 上 传 文件 进行 重新 
命名 。 在 本 实例 中 ， 成 功 上 传 一 个 文件 之 后 ， 将 弹出 新 的 文件 名 称 对 话 框 ， 如 图 4.21 所 示 。 


A 文件 名 被 和 的 为 T24020100710062127 经 验 技 巧 rr 


图 4.21 重新 定义 上 传 文件 名 称 


力 关键 技术 


在 本 实例 中 ， 实 现 文件 上 传 的 功能 ， 有 关 文 件 上 传 的 技术 请 参考 本 章 实例 224， 这 里 不 再 次 述 。 下 面 将 介 
绍 一 种 给 上 传 文件 命名 的 方法 。 

basenameO 函 数 ， 返 回 指定 文件 目录 中 的 基本 文件 名 ， 语 法 如 下 : 

string basename(string path [ string suffix]) 

参数 path 指定 文件 的 路 径 ， 参 数 suffix 为 可 选 参数 ， 如 果 文 件 路 径 以 suffix 结尾 ， 那 么 这 部 分 内 容 将 被 
删除 。 

通过 此 函数 获取 到 上 传 文件 的 原始 名 称 ， 并 对 这 个 名 称 进行 重新 定义 ， 进 而 避免 在 将 文件 上 传 到 服务 器 时 
出 现 重 名 的 问题 。 
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设计 过 程 
上 传 文件 的 具体 实现 步骤 可 以 参考 本 章 实例 224， 这 里 不 再 更 述 。 
在 本 实例 中 ， 关 键 是 在 定义 上 传 文件 的 名 称 时 ， 应 用 随机 函数 mt rand0、 时 间 戳 以 及 basename0 函 数 ， 其 
关键 代码 如 下 : 
Sdate=date("YmdHis"); // 定 义 随机 数 
$filename=mt rand(1000.9999).$date.basename($_FILES[up_picture][mame]): /定义 上 传 文件 名 称 


echo "<script>alert( 文 件 名 被 蔡 换 为 "$filename.");</script>"; 
$path= upfile/.$filename: /定义 上 传 文件 名 称 和 存储 位 置 


图 秘笈 心 法 


心 法 领悟 241: 上 传 文件 原始 名 称 的 获取 。 
在 通过 表单 中 的 文件 域 提交 上 传 文件 时 ， 如 果 在 form 中 定义 了 enctype="multipart/form-data" 属 性 ， 那 么 在 
获取 上 传 文件 的 原始 名 称 时 必须 使 用 $_FILES 全 局 变量 ， 如 果 使 用 $_POST 是 获取 不 到 值 的 。 


| 
趣味 指数 ， 请 记 让 页 家 


力 实例 说 明 


设想 这 样 一 个 场景 ， 若 知道 某 个 网 站 中 一 个 文件 的 具体 路 径 ， 我 们 在 本 地 就 可 以 完成 对 这 个 文件 内 容 的 读 
取 操 作 ， 这 将 是 一 件 多 么 有 趣 的 事情 。 本 实例 就 将 这 个 场景 变 为 现实 ， 实 现 读 取 远 程 文 件 的 功能 ， 运 行 结果 如 
图 4.22 所 示 。 


左 | 该 取 远 程 文件 的 内 容 


远程 文件 地 址 : [Pttp77192 168 1.227/mrtxt A 
< 一 一 和 
NG ~ 
| | 
| 区 一 下 | 


所 路径、 文件 名 称 少 须 是 英文 字符 串 


党 览 远 枉 文件 四 内 容 本 荫 


copyright 1999-2010 站 林 池 BRRAN 
图 4.22 读 取 远 程 文件 的 数据 


上 说 明 : 此 功能 的 实现 会 有 诸多 的 阻碍 ， 例 如 ， 服 务 器 不 支持 文件 的 远程 操作 、 访 问 的 文件 不 具备 读 的 权限 
等 。 这 里 只 是 通过 这 样 一 个 实例 ， 告 诉 大 家 如 何 实现 远程 文件 的 访问 操作 。 如 果 服务 器 支持 文件 的 
远程 访问 ， 那 么 会 有 一 定 的 安全 隐患 。 

图 关键 技术 

访问 远程 文件 应 用 fopen0 函 数 ， 只 要 将 其 参数 flename 的 值 设置 为 一 个 完整 的 URL 地 址 即 可 。 
LEBg 技巧 : 在 PHP 中 ， 如 果 要 访问 远程 文件 ， 必 须 将 配置 文件 php ini 中 的 参数 allow_url fopen 设置 为 开启 。 


allow_ url fopen 参数 默认 是 开启 的 ， 允 许 打 开 http 协议 和 名 协议 指定 的 远程 文件 ， 如 果 
allow_ url fopen 设置 为 o 人 f， 则 不 允许 打开 远程 文件 ， 函 数 将 返回 FALSE。 
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图 设计 过 程 


(1) 创建 index.php 文件 。 首 先 ， 设 计 网 页 页 面 。 然 后 ， 创 建 一 个 表单 ， 通 过 文本 框 提交 要 访问 的 远程 文 
件 的 地 址 。 最 后 ， 获 取 表单 中 提交 的 远程 文件 路 径 ， 并 通过 header0 函 数 跳 转 到 read.php 文件 中 ， 在 该 文件 中 完 
成 对 远程 文件 的 读 取 操作 。index.php 文件 的 关键 代码 如 下 : 


<?php 

if($_POST ['files]!=""){ 

Sfilenames=urlencode($ POST [filesT): 
header("Location: read.php?filename=$filenames"”); 
! 


> 
(2) 创建 read.php 文件 ， 获 取 header0 函 数 传递 的 参数 值 ， 应 用 血 e0 函 数 读 取 参数 值 中 传递 的 远程 文件 ， 

并 通过 foreach0 语 句 输出 远程 文件 的 内 容 ， 其 代码 如 下 : 

<?php 

Sfilename =iconv ( "utf-8", "gb2312", $_GET['filename] ); /获取 header0 函 数 传递 的 参数 值 

Sarr = file ( $filename) ; // 读 取 远程 文件 的 内 容 

foreach ( $arr as $value ) { /循环 输出 数据 

echo htmlspecialchars ( iconv ( "gb2312" "utf-8", $value ) )."<br>"; 

} 

> 


力 秘笈 心 法 


心 法 领悟 242: 不 被 看 好 的 远程 文件 访问 功能 。 
严格 地 说 ， 远 程 文件 的 访问 功能 在 生产 环境 是 不 被 支持 的 ， 因 为 它 涉及 到 服务 器 中 文件 的 安全 问题 ， 所 以 
在 大 多 数 的 服务 器 中 ，allow_url_fopen 的 值 都 是 关闭 的 。 


实例 243 


力 实例 说 明 


在 本 实例 中 ， 将 完成 一 个 具体 的 操作 一 一 删除 指定 目录 下 的 所 有 .ini 文件 ， 其 运行 结果 如 图 4.23 所 示 。 


当前 目录 :FIApPServwwwIMRIO40D3 
项 目 名 


大 小 创建 日 期 量 后 修改 时 间 的 作 
起 定 目录 2040.07.070312:19 2010.07.0703.1220 扣除 
上 如 目录 目录 2010.0630010548 2010.06.30010530 a 
index php 5116 2010.07.07 03:12.19 2010.07070328:14 miex php 
dekete php 713 2010.07.0703:1219 2010.07.01 090628 dekte php 
hook flephp = 876 C2010.07.070312:19 2010.07.07032546 look_fle php 
IMAGES 目录 2040.07.0703:12:19 2010.07.07 034220 IMAGES 
也 轩 文 件 i 0 2010.07.07032643 2010.07.07 0326.44 MI 
phpini 0 2010.07.07 0326232 2010.07.070326:44 | 扣除 | 


有 1 CopyRithts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.23 删除 指定 目录 下 的 所 有 .ini 文件 


图 关键 技术 


有 关 目 录 、 文 件 的 删除 方法 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 就 不 再 袭 述 。 删 除 指定 目录 下 特定 格式 文件 
的 实现 原理 与 删除 所 有 文件 相同 ， 只 是 在 创建 删除 链接 前 对 文件 的 格式 进行 判断 ， 如 果 文 件 是 .int 类 型 ， 那 么 就 
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输出 删除 的 超 链接 ， 和 否则 将 直接 输出 文件 的 名 称 ， 其 关键 代码 如 下 : 


Scatalog = getcwd 0 . "\\Sgain_directory":; /他 目录 
$ext = substr ( $gain_directory, stmpos ( $gain_directory, "." ) ); /获取 文件 的 后 缀 
f(strtoupper ( $ext )—".INI") { 1/ 判断 如 果 文 件 的 后 组 是 .ini， 则 创建 删除 超 链接 
echo "<a href='delete.php?catalog=".urlencode($catalog)."&-filename=”. urlencode(getcwd 0) . " title=' 删 除 目 录 或 者 文件 ' > 删除 </a>": 
}else { /如 果 文 件 的 后 缀 不 是 .ini， 则 直接 输出 文件 名 称 
echo iconv ( "gb2312", "utf-8", Sgain directory ); 
1 
图 设计 过 程 


(1) 本 实例 index.php 文件 的 创建 过 程 与 遍历 、 删 除 指定 目录 下 的 所 有 文件 是 基本 相同 的 ， 不 同 之 处 已 经 
在 关键 技术 中 给 出 ， 这 里 不 再 袭 述 。 
(2) 创建 look filephp 文件 ， 完 成 对 .ini 后 级 文件 的 读 取 操作 ， 其 代码 如 下 : 
En =iconv ( "utf-8", "gb2312", urldecode ($_GET [catalog] ) ); 
Sfilename = iconv ( "utf-8", "gb2312", urldecode ( $_GET [filename] ) ); $type = iconv ( "utf-8", "gb2312", urldecode ( $_GET [type] ) );，// 获 取 文件 
的 信息 ,设置 编码 


Sarr = file ( $catalog . "\\" . $filename ): /1/ 读 取 文件 

foreach ( $arr as $value ) { /循环 输出 文件 内 容 
Svalue = htmlentities ( $value, ENT_COMPAT, "UTF-8" ); /特殊 字符 的 转换 
echo $value . "<br>"; /输出 内 容 


} 

> 

(3) 创建 deletephp 文件 ， 完 成 对 指定 文件 的 删除 操作 ， 代 码 请 参考 本 书 光盘 。 
图 秘笈 心 法 

心 法 领悟 243: 合理 地 运用 自己 的 编程 资源 。 

在 进行 程序 开发 的 过 程 中 ， 要 学 会 合理 地 运用 自己 的 编程 资源 。 一 个 好 的 功能 模块 ， 不 只 是 在 一 个 程序 中 
可 以 使 用 还 应 具有 重用 价值 。 诸 如 数据 库 的 连接 、 操 作 方 法 以 及 分 页 技术 等 ， 一 次 开发 后 将 会 在 很 多 的 程序 中 
使 用 ， 避 免 对 类 似 程 序 进行 重复 开发 ， 浪 费 不 必要 的 时 间 。 

作为 一 个 程序 员 ， 不 只 要 每 次 在 开发 时 都 考虑 新 的 功能 、 新 的 技术 ， 更 重要 的 是 充分 运用 已 有 资源 ， 既 可 
以 提高 程序 的 开发 效率 ， 又 可 以 避免 开发 新 技术 产生 的 一 些 问题 。 


实例 244 


图 实例 说 明 

文本 文件 中 的 数据 也 可 以 转 存 到 数据 库 中 。 例 如 ， 在 编程 词典 服务 网 中 ， 有 一 个 编程 词典 系列 软件 注册 信 
息 提 交 页 面 ， 在 该 页 面 中 ， 编 程 词典 用 户 不 但 提交 个 人 信息 ， 而 且 将 安装 编程 词典 生成 的 注册 信息 文件 提交 
到 服务 器 中 ， 在 提交 注册 信息 的 同时 ， 将 注册 信息 中 的 数据 与 用 户 个 人 信息 一 起 存储 到 数据 库 中 。 本 实例 模拟 
这 个 功能 ， 开 发 一 个 将 文本 文件 上 传 到 服务 器 ， 并 且 将 文本 文件 中 数据 转 存 到 数据 库 中 的 实例 ， 其 运行 结果 如 
图 4.24 所 示 。 


图 关键 技术 


本 实例 运用 了 三 方面 的 技术 : 第 一 ， 将 文本 文件 上 传 到 服务 器 ; 第 二 ， 读 取 服 务 器 指定 文件 夹 下 文本 文件 
中 的 数据 ;第 三 ， 连 接 数 据 库 ， 将 从 文本 文件 中 读 取 的 数据 存储 到 指定 数据 表 中 。 
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I S200R RH 
选择 上 传 文件 : ‘A 


[FwppsevwwwMROAT ER i 
上 全 文件 闫 型 为 ( ini) 
”As 人 编程 间 典 注册 信息 担 讼 


名 称 : 1278561197ini 时 间 : 2010.07.08 0333:17 | 


望 门 投 止 思 张 俭 ， 忍 死 须 奥 待 福 根 .我 自 锥 刀 向 天 舌 ， 去 留 肝 胆 两 昆仑 。 | 


'@ 我 已 填写 完成 ,确认 提交 


(0 1999.2009 放 林 兴 明日 科技 有 限 公司 
图 4.24 将 文本 文件 存储 到 数据 库 中 


其 中 ， 最 为 关键 的 是 将 文本 文件 中 的 数据 存储 到 数据 库 中 ， 在 执行 数据 的 读 取 和 存储 时 ， 有 两 个 细节 必须 
把 握 。 第 一 个 ， 应 用 addslashesO 函 数 ， 对 从 文本 文件 中 读 取 的 数据 进行 转 义 ， 因 为 在 读 取 的 数据 中 可 能 包含 单 
引号 () 、 双 引号 (") 、 反 斜 线 (\) 或 者 NUL (NULL 字符 ) ， 如 果 不 对 其 进行 转换 ， 在 执行 SQL 语句 时 
可 能 会 出 现 错误 。 

addslashesO 函 数 ， 通 过 反 和 斜 线 来 引用 字符 串 ， 语 法 如 下 : 

string addslashes ( string str) 

在 其 返回 的 字符 串 中 ， 为 了 数据 库 查 询 语句 等 的 需要 在 某 些 特定 字符 前 加 上 了 反 斜 线 ， 这 些 特定 字符 包括 
单 引号 (') 、 双 引号 〈") 、 反 和 斜 线 (\) 和 NUL (NULL 字符 ) 。 


上 说 明 : 默认 情况 下 , PHP 指令 会 自动 对 所 有 的 GET、 POST 和 COOKIE 数据 运行 addslashesO 函 数 。 所 以 ， 
如 果 是 通过 GET 或 者 POST 方法 提交 的 数据 是 不 需要 进行 转 义 的 , 可 以 直接 添加 到 数据 库 中 ; 如 果 
提交 的 数据 是 从 文本 文件 中 读 取 或 者 自 定义 的 内 容 ， 那 么 就 有 必要 对 其 进行 转 义 。 


图 设计 过 程 
(1) 创建 index.php 文件 。 首 先 ， 设 计 网 页 页 面 。 然 后 ， 创 建 一 个 表单 ， 通 过 文件 域 提交 要 上 传 的 .ini 
文件 。 接 着 获取 表单 中 提交 的 文件 ， 将 文件 存储 到 服务 器 指定 的 文件 夹 下 ， 通 过 多 e_get_contents0 函 数 读 取 


上 传 文件 的 内 容 ， 并 且 将 读 取 的 结果 存储 到 指定 的 数据 表 中 。 最 后 ， 执 行 查询 语句 ， 输 出 数据 库 中 存储 的 .ini 
文件 的 内 容 ， 其 关键 代码 如 下 : 


< 


if(! empty ( $_FILES [up_picture] [name] )) { 1/ 判断 上 传 内 容 是 否 为 空 
Stype = $_FILES [up_picture] [name’]; 
Stypes = strstr ( $type, "); /获取 文件 后 级 
if ($types — "ini") { 
if($_FILES [up_picture] [error] > 0) { /天 断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 


switch ($_FILES [up_picture] [error]) { 
1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break: 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 


case3 : 


echo "上 传 文件 不 全 " 
break: 


Case 4: 
echo "没有 上 传 文件 "; 
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break 
1 
}elsef 
if(!is dir ("./upfile")) { 1/ 判断 指定 目录 是 否 存 在 
mkdir ( "./upfile/" ); /| 创建 目录 
} 
Sfile name = time 0 . strstr ( $_FILES [mp_picture] [name].…): /定义 上 传 文件 名 称 
Spath ="./upfile/" . $file_name; /定义 上 传 文件 名 称 和 存储 位 置 
让 (is uploaded file ($_FILES [up_picture] [tmp_name] )) { // 判 断 文 件 是 否 是 HTPP POST 上 传 
这 (! move_uploaded_file ( $_FILES [up _picture] [tmp_name]. $path )) { /执行 上 传 操作 
echo "上 传 失败 "; 
}else{ 
// 读 取 文本 文件 中 数据 ， 并 且 实 现 转 义 和 编码 的 转换 
Sarr = iconv ( "gb2312", "utf-8", addslashes ( file_get_contents ( $path ) ) ); 
include_once ("conn/conn.php"); // 连 接 数 据 库 
$sql = "insert into tb files(file name,file content,file date)values('$file name','$arr,”" . date ( "Y-m-d H:i:s" ) . ")"; 
// 定 义 SQL 添加 语句 
Sresult = mysql_query ( $sql, Sconn ); /| 执行 添加 操作 
echo "文件 ，“" .$_FILES [up_picture'] [name] . ”上 传 成 功 !" . "<br>"; 
echo "大 小 : “" .$_FILES [up_picture] ['size] .” 字 节 "; 
} 
}else{ 
echo "上 传 文件 " . $_FILES [up_pictute] [name] . "不 合法 ! "; 
} 
3 
Yelsef 


echo "上 传 文件 " . $_FILES [up_pictute] [name] . "类 型 不 正确 ! "; 
} 
} 


?> 
(2) 创建 conn 文件 夹 , 编写 conn.php 文件 ,连接 数据 库 服务 器 , 连接 db _database04 数据 库 ， 其 代码 如 下 : 


<?php 

$conn = mysql_connect ( "localhost", "root", "111" ) or die ( "连接 数据 库 服务 器 失败 ! " . mysql_error 0 ); 
Imysql_select_db ( "db_database04", $conn ); // 选 择 数 据 库 db_database04 
mysql_query ( "set names utf8" ); // 设 置 数据 库 编 码 格式 utf-8 
> 


图 秘笈 心 法 

心 法 领悟 244: addslashes0 转 义 函数 的 合理 运用 。 

将 从 文本 文件 中 读 取 的 数据 存储 到 数据 库 时 ,必须 应 用 addslashes0 函 数 对 文本 文件 返回 的 字符 串 进行 转 义 ， 
否则 有 可 能 出 现 如 图 4.25 所 示 的 错误 。 


ee) 
上 传 文件 闫 型 为 C ni) 


You have an eror in your SQL syntax, check the manual that comesponds to your MySQL server version for the right syntax to 
ase near 's behavior. in order for PHP to ;mead it, i must be named php inf PHP Jo et line 1 


图 4.25 数据 添加 失败 


4.5 文件 的 压缩 与 解压 


WinRAR 是 一 个 非常 实用 的 文件 压缩 管理 工具 ， 利 用 其 强大 的 功能 可 以 很 方便 地 将 多 个 文件 压缩 成 为 一 个 
文件 ， 这 样 不 仅 可 以 方便 操作 ， 而 且 可 以 在 很 大 程度 上 节省 文件 存储 的 空间 。 本 节 将 向 读者 介绍 如 何 利 用 PHP 
解压 缩 和 解压 缩 文件 。 
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去 一 


可 


趣味 指数 : 全 寅 二 真人 页 ; 


图 实例 说 明 


在 网 站 中 ， 上 传 的 文件 大 多 数 都 是 以 压缩 包 的 形式 存在 的 ， 所 以 先 将 要 上 传 的 文件 压缩 后 才能 够 上 传 ， 如 
果 能 在 网 站 中 增加 上 传 文件 自动 压缩 模块 ， 将 会 给 用 户 带 来 很 大 的 方便 。 本 实例 将 向 读者 介绍 如 何在 PHP 中 完 
成 文件 的 压缩 操作 。 运 行 本 实例 ， 首 先 选 择 要 压缩 的 文件 ， 然 后 设置 压缩 文件 的 存储 位 置 ， 单 击 “ 提 交 ” 按 钮 ， 
运行 结果 如 图 4.26 所 示 。 


指定 压 蓉 文件 ; 丰 WAppServ Wm WIRVD4\025\ 条 于 广 IE 
定义 压 编 文件 存储 位 置 ; 民 WAppServ Wm WRVO4V025\ 新 建文 件 实 提交 


设置 不 嫩 文 件 存 诸位 置 ( 例如 ;《 FIAPPServwnwwMRIO40257 9 
ee 


如 1 CopyRithts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.26 RAR 压缩 文件 

图 关键 技术 

文件 压缩 主要 应 用 PHP 的 预定 义 类 com， 将 wscript.shell 对 象 作 为 com 类 的 参数 ， 最 终 通过 调用 com 类 的 
mn() 方 法 实现 文件 的 压缩 。 

com 类 ， 提 供 一 个 将 COM 组 件 整合 到 PHP 脚本 中 的 框架 ， 实 例 化 方法 如 下 : 

$obj = new COM("server.object") 

COM 类 构造 函数 的 语法 如 下 : 

string COM::COM ( string module_name [. string server_name [, int codepage]] ) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 ， 组 件 在 此 服务 器 上 被 取 用 。 如 果 是 NULL， 则 假定 是 localhost。 如 果 
要 支持 允许 DCOM， 必 须 将 php.ini 中 的 com.allow_dcom 设 为 TRUE。 

codepage: 指定 用 于 将 PHP 字符 串 (php-strings) 转换 成 UNICODE 字符 串 (unicode-strings〉 的 代码 页 ， 
反之 亦 然 。 可 用 的 值 为 CP_ACP、CP_MACCP、 CP OEMCP、 CP_SYMBOL、 CP THREAD ACP、CP UTF7 和 
CP_UTFS. 

com 类 中 rn0 方 法 的 语法 如 下 : 

run("winrar a 生成 的 rar 文 件 的 路 径 及 名 称 要 压缩 的 文件 的 路 径 及 名 称 ".1.false); 
国 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 创 建 一 个 表单 ， 设 置 文件 域 ， 提 交 要 压缩 的 文件 ， 设 置 文本 框 ， 提 交 压 
缩 文 件 的 存储 位 置 ， 设 置 按钮 ， 完 成 表单 元 素 的 提交 操作 。 
(2) 在 index.php 文件 中 编写 PHP 脚本 , 通过 $_POST[] 方 法 获取 表单 提交 的 数据 ， 通 过 iconv0 函 数 完成 数 

据 编码 格式 的 转换 ， 实 例 化 com 类 ， 调 用 run0 方 法 完成 文件 的 压缩 操作 ， 其 关键 代码 如 下 : 


<?php 
if($_POST [Submit] = "") { 
$sourcefile = iconv ( "utf-8", "gb2312", $ POST [sourcefile] ); /获取 指定 文件 的 路 径 
S$objfile=$ POST [objfile] . "\" .time 0: /定义 压缩 文件 的 存储 位 置 和 名 称 
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Sobijfile =iconv ( "utf-8", "gb2312", Sobjfile ): // 实 现 编码 转换 
S$obj = new com ( "wscriptshell" ); /实例 化 com 类 
Sobj->run ( "winrar a " . Sobjfile ." " . $sourcefile . "". 1, false ): // 调 用 类 中 的 方法 


echo "<script>alert( 文 件 压缩 完成 !):</script>"; 
证 


> 


国 秘笈 心 法 


心 法 领悟 245: 执行 文件 压缩 操作 的 误区 。 
在 执行 文件 压缩 操作 时 ， 切 忌 在 文件 的 存储 路 径 中 出 现 空格 (包括 被 压缩 文件 的 路 径 、 名 称 以 及 压缩 文件 
的 存储 路 径 ) ， 否 则 压缩 操作 将 不 会 正确 执行 。 


高 级 | 
二 朱 才 机 


图 实例 说 明 
在 本 实例 中 ， 实 现 将 上 传 的 文件 直接 以 压缩 文件 的 格式 进行 存储 ， 其 好 处 是 可 以 缓解 服务 器 的 压力 、 节 省 
服务 器 的 空间 。 运 行 本 实例 ， 选 择 要 上 传 的 文件 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.27 所 示 。 
i ne 
欢迎 未 到 明日 ;x 件 鲁 理 系 统 ! 


1 


选择 上 传 文件 :EWDocoments and SettintzWdnin 区 放 2 提交 


文件 : cmmateanlhttp ja 上 传 成 功 9 
大 小 : 3 和 2 字 节 
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图 4.27 将 上 传 文件 转换 成 压缩 文件 
上 传 成 功 后 ， 可 以 查看 本 实例 根 目录 下 的 upfile 文件 夹 ， 确 定 上 传 文件 是 否 以 压缩 文件 的 格式 进行 存储 。 
图 关键 技术 


本 实例 实现 文件 上 传 技术 与 文件 压缩 技术 的 结合 ， 进 而 实现 将 上 传 文件 以 RAR 格式 进行 存储 。 其 中 在 调用 
com 类 中 的 run0 方 法 执行 压缩 操作 时 ， 在 winrar 的 命令 中 ， 增 加 了 两 个 属性 : “-ep” 将 压缩 文件 以 文件 名 的 格 


式 进 行 存储 ， 不 包括 文件 的 路 径 ，“-df” 文 件 压 缩 成 功 后 删除 原始 文件 ， 其 完整 的 命令 语句 如 下 : 
$obj->run ( "winrar a -ep -df ". $file_path.".rar" ."" . $path . "", 1, false ): // 调 用 类 中 的 方法 ， 执 行文 件 压缩 操作 


力 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 创 建 一 个 表单 ， 设 置 文 件 域 ， 提 交 上 传 文件 ， 设 置 按钮 ， 完 成 表单 元 素 
的 提交 操作 。 

(2) 在 index.php 文件 中 编写 PHP 脚本 。 首 先 ， 对 上 传 文件 进行 判断 ， 如 果 符 合 要 求 将 上 传 文件 存储 到 服 
务 器 指定 文件 夹 下 。 然 后 ， 实 例 化 PHP 中 的 com 类 ， 通 过 rn0 方 法 执行 文件 的 压缩 命令 ， 完 成 上 传 文件 的 压 


缩 操作 ， 并 将 原始 文件 删除 ， 其 关键 代码 如 下 : 
/定义 上 传 文件 名 称 和 存储 位 置 
Spath = upfilen . time () . strstr ( $ FILES sourcefile] fname, " ): 
if(is_uploaded file ( $_FILES [sourcefile] [tmp_name])){ 
if (! move_uploaded file ( $_FILES [sourcefile] [tmp_name]. $path )) { echo "上 传 失败 ": 
}else { 
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Spath = realpath ( iconv ( "utf-8", "gb2312", $path ) ): /获取 文件 在 服务 器 中 的 路 径 
Slen = strripos ( $path. "." ); /| 计算 路 径 的 长 度 

Sfile_path = substr ( $path, 0, $len ): /获取 上 传 文件 的 路 径 名 称 
Sobj = new com ( "wscript.shell"” ); /实例 化 com 类 


// 调 用 类 中 的 方法 ， 执 行文 件 压缩 和 原始 文件 删除 操作 
Sobj->run ( "winrar a -ep -df ". $file path. "rar"."". $path. ™, 1, false ); 
echo "文件 :" .$_FILES [sourcefile] [name] . "上 传 成 功 ! ". "<br>"; 
echo "大 小 : ".$_FILES [sourcefile] [size] . " 字 节 ": 

}elsef 

echo "上 传 文件 ". $_FILES [sourcefile] [name] . "不 合法 !"; 
} 


图 秘笈 心 法 


心 法 领悟 246: winrar 操作 命令 的 运用 。 
对 RAR 文件 进行 操作 的 命令 , 不 只 r、-ep 和 -df 这 3 个 ,还 有 很 多 ， 读 者 可 以 参考 RAR 用 户 手 册 了 解 更 多 
关于 RAR 操作 的 命令 。 


高 级 
趣味 指数 ， 傅 禄 诊 认 


力 实例 说 明 


既然 已 经 介绍 了 如 何 对 文件 进行 压缩 ， 那 么 必然 要 介绍 如 何 对 压缩 文件 进行 解压 。 运 行 本 实例 ， 首 先 选择 
要 解压 的 RAR 文件 ， 并 在 文本 框 中 输入 要 解压 文件 的 存储 目录 ， 单 击 “解压 ”按钮 即 可 ， 运 行 结 果 如 图 4.28 
所 示 。 
欢迎 有 来 到 明日 又 件 管 理 系 统 


指定 压 纳 文 件 : 民 VAppServirrs RVO4 W026\op ET 交 | 
定义 解压 文件 存储 位置 : 克 AppServiw WRVD4V027 解压 
设 秆 压 纺 文 件 存 请 位 置 ( 例 各 :《 FWAppSeviwwwiMRI04027 9 
和 NL Copy 二 e reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.28 解压 RAR 文件 
图 关键 技术 
文件 解压 同样 应 用 PHP 的 预定 义 类 com, 将 wscript.shell 对 象 作为 com 类 的 参数 ,通过 调用 com 类 的 run0 


方法 执行 文件 解压 的 命令 。 文 件 解压 的 命令 如 下 : 
$obj->run ( "winrar x -av -c ".$sourcefile." ".$objfile. "", 1. tme ): 。 // 调 用 类 中 的 方法 ， 执 行文 件 解压 的 命令 


通过 此 命令 将 指定 的 压缩 文件 解压 到 指定 的 绝对 路 径 下 。 
图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 创 建 一 个 表单 ， 设 置 文件 域 ， 提 交 要 解压 的 文件 ， 设 置 文本 框 ， 提 交 解 
压 后 文件 的 存储 位 置 ， 设置 按钮 ， 完 成 表单 元 素 的 提交 操作 。 

(2) 在 index.php 文件 中 编写 PHP 脚本 ， 通 过 $_ POST[] 方 法 获取 表单 提交 的 数据 ， 通 过 iconv0 函 数 完成 数 
据 编码 格式 的 转换 ， 实 例 化 com 类， 调用 mun0 方 法 执行 文件 的 解压 命令 ， 其 关键 代码 如 下 : 


<?php 
让 (8_POST [Submit] (="") { 


321 


PHP 开发 实战 1200 例 (第 I 卷 ) 


include("finction php"); 
$sourcefile = iconv ( "utf-8", "gb2312", unhtml($_POST [sourcefile]) ): /获取 指定 文件 的 路 径 
S$objfile = iconv ( "utf-8". "gb2312", $_ POST [objfile] ); /定义 解压 文件 的 存储 位 置 和 名 称 
S$obj = new com ( "wscriptshell" ); // 实 例 化 com 类 
Sobj->run ( "winrar x -av -c ".$sourcefile." ".$objfile. ™. 1, true ): // 调 用 类 中 的 方法 ， 执 行 解压 命令 
echo "<script>alert( 文 件 解压 完成 "):</script>"; 

} 


?> 


力 秘笈 心 法 


心 法 领悟 247: 执行 文件 解压 操作 的 误区 。 
在 执行 文件 解压 操作 时 ， 切 鼠 在 文件 的 存储 路 径 中 出 现 空格 〈 包 括 被 解压 文件 的 路 径 、 名 称 以 及 解压 后 文 
件 的 存储 路 径 ) ， 否 则 解压 操作 将 不 会 正确 执行 。 


高 级 
趣味 指数 : 坪 寅 寅 宣 突 


力 实例 说 明 

通过 PHP 不 但 可 以 将 文件 压缩 成 RAR 格式 , 而 且 可 以 将 文件 压缩 成 ZIP 格式 , 本 实例 将 介绍 如 何 应 用 PHP 
将 文件 压缩 成 ZIP 格式 。 运 行 本 实例 ， 首 先 选择 要 压缩 的 文件 ， 然 后 设置 压缩 文件 的 存储 位 置 ， 单 击 “提交 ” 
按钮 即 可 ， 运 行 结 果 如 图 4.29 所 示 。 
欢迎 采 到 明日 尖 仁 
= 


指定 ZIP 压 缩 文件 : 天 WAppServ wre WR\D4\026\IIDEY 有 KR 


设置 ZIP 压 缩 文件 存储 位 置 ( 例如 :〈 F\AppServiwwwiMRIO4028W zip) 9 
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图 4.29 ZIP 压缩 文件 


图 关键 技术 


运用 PHP 将 文件 压缩 成 ZIP 格式 的 原理 与 压缩 成 RAR 格式 的 原理 相同 : 首先 ， 运 用 PHP 的 预定 义 类 com 
调用 系统 中 安装 WinRAR 后 所 形成 的 组 件 wscript.shell， 并 对 com 类 进行 实例 化 。 然 后 ， 调 用 com 类 中 的 run0 
方法 执行 文件 的 压缩 命令 。 对 com 类 进行 实例 化 及 调用 类 中 run0 方 法 的 代码 如 下 : 
Sobj=new com("wscript.shell"); 
Sobj->run("winrar a "Sobjfile ""Ssourcefile ,1.false):。 
图 设计 过 程 
(1) 创建 index.php 文件 。 编 写 form 表单 ， 提 交 被 压缩 文件 和 压缩 文件 的 存储 位 置 及 名 称 。 
(2) 在 index.php 文件 中 ,编写 PHP 脚本 ,通过 $_POST[] 方 法 获取 表单 提交 的 数据 ， 通 过 iconv0 函 数 完成 
数据 编码 格式 的 转换 ， 实 例 化 com 类 ， 调 用 run0 方 法 完成 文件 的 压缩 操作 ， 其 关键 代码 如 下 : 
<?php 


if($_POST ['Submit] ="") { 


$sourcefile = iconv ( "utf-8", "gb2312", $_POST [sourcefile] ): /获取 指定 文件 的 路 径 
S$objfile = iconv ( "utf8". "gb2312". $_POST [objfile] ): // 实 现 编码 转换 
S$obj = new com ( "wscript.shell” ): /实例 化 com 类 
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$obj->run ( "winrar a -ep " . $objfile . " " . $sourcefile . "", 1. false ); /1/ 调 用 类 中 的 方法 ， 执 行文 件 压缩 操作 
echo "<script>alert( 文 件 压缩 完成 '):</script>"; 
上 


> 


图 秘笈 心 法 


心 法 领悟 248: 将 上 传 文件 转换 成 ZIP 文件 。 
将 上 传 文件 转换 成 ZIP 文件 与 将 上 传 文件 转换 成 RAR 文件 相同 ， 都 是 运用 winrar 中 a、-ep 和 -df 命令 ， 具 
体 步 骤 可 以 参考 实例 247。 


实例 249 趣味 指数 : fa 


图 实例 说 明 
既然 可 以 完成 ZIP 文件 的 压缩 , 那么 一 定 也 可 以 实现 对 ZIP 文件 的 解压 操作 。 本 实例 将 介绍 如 何 实现 对 ZIP 
文件 的 解压 。 运 行 本 实例 ， 首 先 选 择 要 解压 的 ZIP 文件 ， 并 在 文本 框 中 输入 要 解压 文件 的 存储 目录 ， 单 击 “ 解 
压 ” 按 钮 即 可 ， 运 行 结果 如 图 4.30 所 示 。 
| XX i 来 到 | 


2 二 
p 人 
人 心 ZTP 压 弟 文 件 解压 完成 ! 
选择 ZIP 压 缩 文件 : 到 
定义 解压 文件 存 铺位 置 : 大 一 一 Ea 


设置 解压 文件 存储 位 置 ( 例如 :( FWAppServiwwwiMRW04029 ) 9 
各 1 CopyRights © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.30 ”ZIP 文件 解压 


力 关键 技术 

解压 ZIP 文件 同样 应 用 PHP 的 预定 义 类 com， 具 体 参考 实例 247 的 关键 技术 部 分 。 
图 设计 过 程 

具体 设计 过 程 请 参见 实例 247。 
图 秘笈 心 法 


心 法 领悟 249: 解压 ZIP 文件 时 ， 压 缩 文件 和 解压 文件 的 存储 路 径 中 不 可 以 有 空格 。 
在 执行 解压 ZIP 文件 的 操作 时 ， 压 缩 文 件 和 解压 文件 的 存储 路 径 中 不 可 以 有 空格 ， 即 不 允许 出 现 
C:\Documents and Settings\ 或 者 E:\Program Files\ 此 类 目录 ， 和 否则 解压 操作 将 不 会 正确 执行 。 


46 目录 操作 


在 网 站 的 服务 器 上 ， 目 录 是 必 不 可 少 的 ， 因 为 它 可 以 把 文件 进行 分 类 存放 ， 方 便 管理 者 查找 ， 所 以 对 目录 
进行 在 线 管理 是 非常 必要 的 。 


趣味 指数 : 二 直 丰 相让 


图 实例 说 明 


在 前 面 的 实例 中 ， 已 经 涉及 到 很 多 目录 操作 的 方法 ， 如 创建 目录 、 获 取 当 前 目录 、 删 除 目录 等 。 在 本 实例 
中 ， 将 对 目录 的 基本 操作 进行 一 次 汇总 ， 让 读者 对 目录 操作 方法 有 一 个 系统 的 了 解 。 运 行 本 实例 ， 可 以 实现 目 
录 的 创建 、 浏 览 和 删除 操作 ， 其 运行 结果 如 图 4.31 所 示 。 


i 


Mingri Files Management System 
? 欢迎 用: 到 明日 文体 管理 系统 
yy i Fe 
| 当前 目录 ，FiAPpServwweMRO4 
下 G 1 
| 
3: images 
4: delete php 
5S: dejetedir php 
Gicss 
S 7: deletefile php 
© 3: create php 
6 9: 新 建文 件 来 
6 10: bok php 
11:INDEX PHP 
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图 4.31 目录 操作 汇总 


力 关键 技术 


本 实例 主要 应 用 mkdir0、is_dir0、getcwd0、rmdir0，opendir0 和 readdir0 函 数 等 ， 完 成 目录 的 判断 、 创 建 、 
打开 、 读 取 和 删除 操作 。 所 使 用 函数 的 功能 和 语法 如 表 4.2 所 示 。 


表 4.2 目录 操作 函数 汇总 


法 功 能 

新 建 一 个 由 pathname 指定 的 目录 。 参 数 mode 指定 目录 的 模式 ， 
bool mkdir(string pathname [. int mode]) ”| 在 Windows 下 被 忽略 、 自 PHP 4.2.0 起 成 为 可 选项 。 默认 的 
mode 是 0777， 意 味 着 最 大 可 能 的 访问 权 
如 果 文 件 名 存在 并 且 为 目录 则 返回 TRUE。 如 果 包 ename 是 一 
个 相对 路 径 ， 则 按照 当前 工作 目录 检查 其 相对 路 径 

_getcwdO _ | string getcwd (void) 返回 当前 的 工作 目录 

删除 dimame 所 指定 的 目录 。 该 目录 必须 是 空 的 ， 而 且 要 有 相 
应 的 权限 。 如 果 成 功 则 返回 TRUE， 失 败 返 回 FALSE 


bool is_dir ( string filename ) 


rmdir bool rmdir ( string dimame ) 
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续 表 
名 称 功 能 
打开 一 个 目录 句柄 ， 成 功 返 回 目录 句柄 的 Tesource， 失 败 返 回 
FALSE。 返 回 值 可 用 于 closedir0、readdir0 和 rewinddir() 函 数 中 。 
resource opendir ( string path [. resource | 如 果 参 数 path 不 是 一 个 合法 的 目录 或 者 因为 权限 限制 或 文件 系统 
context] ) 错误 而 不 能 打开 目录 ，opendir0 返回 FALSE 并 产生 一 个 
E_WARNING 级 别 的 PHP 错误 信息 。 可 以 在 opendir0 前 面 加 
上 “@” 符 号 来 抑制 错误 信息 的 输出 
从 目录 句柄 中 读 取 条 目 , 成 功 则 返回 目录 中 下 一 个 文件 的 文件 名 ， 
readdir() string readdir ( resource dir handle ) 否则 返回 FALSE。 其 参数 dir handle 是 目录 句柄 的 resource, 之 
前 由 opendir0 打开 


opendir() 


图 设计 过 程 
(1) 创建 index.php 文件 。 通过 switch0 语 句 编写 一 个 网 页 框架 ,根据 超 链 接 中 传递 的 参数 值 ， 在 index.php 
页 面 中 完成 创建 目录 、 浏 览 目录 、 删 除 目录 和 删除 文件 功能 之 间 的 跳 转 ， 其 关键 代码 如 下 : 
<?php 
switch ($_GET [dir]){ 
Case "create" : 
include ("create.php"); 
break: 
case "look" : 
include ("look.php"); 
break: 


case "deletedir" : 
include ("deletedir.php"): 
break: 


case "deletefile" : 
include ("deletefile.php"); 
break: 

default : 
include ("look.php"): 
break: 

} 

?> 


(2) 创建 create.php 文件 ， 应 用 mkdir0 函 数 完成 目录 的 创建 ， 其 关键 代码 如 下 
<?php 
if($ POST T'Submit] ="") { 
Sfile dir=iconv ( "utf-8", "gb2312". $ POST Fobifile] ): 
if(is_dir (Sfile_dir)) { 
echo "<script>alert( 目 录 已 经 存在 !);</script>"; 
} else { 
if (mkdir ( $file dir) { 
echo "<script>alert( 目 录 创 建成 功 );</script>"; 
} else { 
echo "<script>alert(' 目 录 创 建 失败 !"):</script>"; 
1 
} 


(3) 创建 look.php 文件 ， 通 过 getewd0 函 数 定位 到 当前 目录 ， 并 应 用 opendir0 函 数 和 readdir0 函 数 读 取 当 
前 目录 中 的 内 容 ， 其 代码 请 参考 本 书 光 盘 。 

(4) 创建 deletedirphp 文件 ， 在 look.php 文件 的 基础 上 ， 为 输出 的 目录 创建 删除 超 链接 ,链接 到 delete php 
文件 ， 完 成 目录 的 删除 操作 。 
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(5) 创建 deletefile.php 文件 ,在 look php 文件 的 基础 上 ,为 输出 的 文件 创建 删除 超 链接 , 链接 到 deletephp 
文件 ， 完 成 文件 的 删除 操作 。 
(6) 创建 deletephp 文件 ， 分 别 应 用 rmdir0 函 数 和 unlink0 函 数 完成 目录 和 文件 的 删除 。 


图 秘笈 心 法 


心 法 领悟 250: 目录 的 删除 。 
在 应 用 rmdir0 函 数 删 除 指定 的 目录 时 , 被 删除 的 路 径 必须 指向 空 的 目录 , 并 且 该 目录 的 权限 必须 合乎 要 求 ， 
否则 将 返回 FALSE。 


高 级 
趣味 指数 ， 傅 请 宣言 家 


实例 说 明 

在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 经 常会 修改 文件 夹 的 名 称 ， 这 也 是 目录 的 一 项 基本 操作 。 本 实例 将 介 
绍 更 新 目录 名 称 的 方法 。 运 行 本 实例 ， 单 击 当前 目录 中 文件 夹 后 的 “ 重 命 名 ” 超 链接 ， 将 进入 到 如 图 4.32 所 示 
的 页 面 ， 在 这 个 页 面 中 完成 对 指定 目录 的 重 命 名 操作 。 


欢迎 采 到 明日 又 ' 件 管理 系统 


原 目录 名 称 : |F:\AppSerwwwwwNMRND4WO31Y\ 新 建文 件 夫 提交 
日 [ 
新 目录 名 称 : |F: WApp Sor RA prie 目 杂 的 新 名 冤 


如 1 CopyRights © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.32 执行 目录 的 重 命名 


图 关键 技术 
目录 的 重 命名 同样 应 用 的 是 renameO 函 数 ， 有 关 重 命名 的 技术 请 参考 实例 234。 
图 设计 过 程 
(1) 创建 index.php 文件 。 输 出 当前 目录 的 文件 和 目录 信息 ， 并 且 为 输出 的 目录 创建 “ 重 命 名 ”的 超 链接 ， 
其 传递 的 参数 是 指定 目录 的 存储 位 置 和 当前 目录 的 位 置 ， 其 关键 代码 如 下 : 
<table width="650" border="0" cellspacing="0" cellpadding="0"> 
<t> 


<td width="50" height="23">&nbsp:</td> 
<td width="450"><span class="STYLE1"> 当 前 目录 : <?php echo getcwd 0: ?></span></td> 


</tr> 
Slookdir = getcwd 0: /获得 当前 脚本 目录 
Si=0; 
(is_dir ( $lookdir )) { // 检 测 是 否 是 合法 目录 
ff (Sopendir = opendir ( $lookdir )) { /打开 目录 
while ( $li =readdir ( $opendir ) ) { // 读 取 目 录 
> 
<tr> 
<td height="23">&nbsp:</td> 
<td> 
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<td> 


(ii—""|$i—=".") { 
echo "&nbsp;é-nbsp;"; 
} elseif (filetype ( $li ) 一 


Scata = getcwd 0 . "\" .iconv ( "gb2312", "utf-8", $li ); 
> 
<a href="rename .php?catalog—<?php echo urlencode ( $cata ); ?>&dir name=<?php echo urlencode ( getcwd 0 ):?>"title=" 更 新 目录 名 称 " 
target=”blank"> 重 命名 </a> 


<?php} ?> 
<itd> 

</t> 
pp } } } > 
</table> 


(2) 创建 rename.php 文件 ， 根 据 超 链接 传递 的 参数 值 ， 创 建 form 表单 ， 完 成 目录 的 重新 命名 提交 ， 并 且 
在 rename.php 文件 中 完成 重 命名 的 操作 ， 其 关键 代码 如 下 : 


<?php 
让 ($_POST['Submit] 一 "提交") { 


S$old_name=iconv("utf-8","gb2312",$_POST['old_name']); /获取 原始 目录 名 称 
Snew_name=iconv("utf-8","gb2312",$_POST['new_name’]): /获取 新 目录 名 称 
证 (file exists ( $old name )) { 
if (rename ( $old_name, $new_name )) { /把 原 目录 重新 命名 
echo "<script>alert( 目 录 重 命名 成 功 ! "); window.location.href='index.php':</script>"; 
jelse{ 


echo "<script>alert( 目 录 重 命名 失败 ! '); window-.location hre 人 rename.php':</script>" 
} 
}elsef 
echo "<script>alert( 目 录 不 存在 ! "); window.location href='index.php';</script>"; 
» 


下 


图 秘笈 心 法 


心 法 领悟 251: 超 链接 中 参数 值 的 传递 技巧 。 

在 通过 超 链接 的 参数 向 下 一 个 页 面 中 传递 值 时 ， 最 佳 的 方法 就 是 应 用 urlencodeO 函 数 对 参数 值 进行 编码 ， 
其 最 大 的 优点 是 可 以 避免 传递 中 文字 符 串 或 者 空格 时 出 现 乱 码 ， 同 时 还 隐藏 了 传递 的 参数 值 ， 有 一 定 的 保护 
作用 。 


实例 252 


国 实例 说 明 


通过 文件 系统 函数 不 但 可 以 对 目录 、 文 件 进行 操作 ， 获 取 目 录 、 文 件 的 相关 信息 ， 而 且 可 以 获取 磁盘 分 区 
的 大 小 。 运 行 本 实例 ， 将 根据 文本 框 提交 的 目录 ， 获 取 该 目录 所 在 磁盘 分 区 的 大 小 ， 以 及 该 目录 下 的 所 有 文件 。 
运行 结果 如 图 4.33 所 示 。 
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-i 


用 到 明日 双 件 营 


x#a:[ BE 


请 输入 正确 的 目录 ( 例如 : Fwebpegstphp) 
本 地 磁盘 ( F:) 总 大 小 : 2783 GB 可 用 空间 : 1130GB 
FAppServiwwwWiMRWD4W017 目录 下 的 内 容 : 

1 


2: 


3: index] 
4:IMAGES 
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4.33 ”获取 磁盘 分 区 的 大 小 


图 关键 技术 


获取 磁盘 分 区 的 大 小 应 用 的 是 disk_total_space0 函 数 ; 获取 磁盘 分 区 的 剩余 空间 应 用 的 是 disk_ free_space0 
函数 。 


disk total spaceO 函 数 ， -个 目录 的 磁盘 总 大 小 ， 语 法 如 下 : 
float disk_total space ( string directory 


该 函数 根据 参数 directory 提供 的 -个 目录 字符 串 ， 返 回 相应 的 文件 系统 或 磁盘 分 区 的 所 有 字 节 数 。 
< 注意 : 本 函数 不 能 作用 于 远程 文件 ， 被 检测 的 文件 必须 通过 服务 器 的 文件 系统 访问 。 

disk_free_space0 函 数 ， 获 取 一 个 目录 的 可 用 空间 ， 语 法 如 下 : 

float disk_free_space(string directory) 


参数 directory 用 来 指定 文件 系统 或 磁盘 分 区 。 


[| 说 明 : 本 函数 返回 的 是 目录 所 在 的 磁盘 分 区 的 总 大 小 ， 因 此 以 同一 个 磁盘 分 区 的 不 同 目录 作为 参数 所 得 到 
的 结果 完全 相同 。 


图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 添加 表单 ， 设 置 文 本 框 、 提 交 按 钮 ， 使 用 POST 方法 ， 将 数据 提交 到 本 页 。 

(3) 通过 $_ POSTO 获 取 表单 提交 的 目录 路 径 ， 首 先 ， 判 断 获取 的 目录 是 否 合理 。 然 后 ， 通 过 iconv0 函 数 
对 获取 的 字符 串 进行 编码 转换 。 接 着 ， 对 获取 的 字符 串 进行 截取 ， 获 取 该 目录 所 在 的 磁盘 分 区 ， 并 应 用 
disk_total_space0 函 数 获取 磁盘 分 区 的 大 小 。 最 后 ， 应 用 opendir0 函 数 和 readdir0 函 数 读 取 提交 目录 下 的 内 容 。 

index.php 的 关键 代码 如 下 : 


<?php 
if($_POST [file_ name] !="" &é& is file($ POST [file name]) 一 人 alse){ 


$file name = iconv ( "utf-8". "gb2312". $_ POST ['file name'] ): /| 编码 格式 转换 

if (file_exists ( $file name )) { /判断 目录 是 否 存在 
Slen = strripos ( $file name, ":" ); // 戴 取 字 符 串 
Sdir = substr ( $file name. 0. Slen + 1): /获取 提交 目录 所 在 磁盘 
Sfilesize z=disk_total_space ( $dir ); /获取 目录 总 大 小 
Sfilesize z=number format($filesize z/(1024*1024*1024).2.".",""); /项 字 的 格式 化 
Sfilesize_ s=disk free space ( $dir ): /获取 磁盘 剩余 空间 
Sfilesize_s=number format($filesize s/(1024*1024*1024).2.".",""): // 字 节 的 格式 化 
echo "本 地 磁盘 (". $dir . > 总 大 小 : " . $filesize z. "GB &nbsp; 可 用 空间 : ".$filesize_s." GB <br><br>"; 
echo $_POST ['file name'] . ”目录 下 的 内 容 :". "<br>"; 
$i=0; 
Slist = opendir ( $file_ name ): /打开 目录 
while ( $read list = readdir ( $list ) ) { /1/ 读 取 目 录 
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Sitt; 
echo " $i: " .iconv ( "gb2312" “utf-8", Sread list )." <br>": /输出 目录 中 的 内 容 
} 
closedir ( $list ); /关闭 目录 
yelse{ 
echo "<script>alert(' 目 录 不 存在 ! :</script>"; 


¥ 
} else { 

echo "<script>alert( 请 输入 正确 的 目录 路 径 ! :</script>"; 
. 
> 


图 秘笈 心 法 
心 法 领悟 52， strripos0 函 数 ， 判 断 指 定 字符 串 在 另 一 字符 串 中 最 后 出 现 的 位 置 。 


通过 本 函数 可 以 获取 到 指定 字符 串 A 在 另 一 字符 串 B 中 最 后 出 现 的 位 置 ， 其 返回 值 为 nt 型 ， 根 据 这 个 返 
回 值 就 可 以 对 字符 串 B 以 字符 串 A 为 分 隔 点 进行 截取 ， 在 执行 截取 的 操作 时 需要 应 用 到 substr0 函 数 。 


初级 
趣味 指数 : 商 侠 从 


力 实例 说 明 


在 网 站 的 后 台 管理 系统 中 ， 经 常 需要 对 网 站 服务 器 中 的 文件 进行 管理 和 维护 ， 有 时 需要 添加 一 个 文件 夹 或 
删除 某 个 文件 来 或 者 文件 ， 为 了 更 有 效 地 查看 这 些 文件 或 者 文件 夹 ， 最 好 的 方法 就 是 创建 一 个 文件 查询 系统 ， 
通过 它 可 以 查看 到 指定 文件 夹 下 的 所 有 文件 。 运 行 本 实例 ， 在 文本 框 中 输入 一 个 指定 的 文件 夹 ， 单 击 “ 提 交 ” 
按钮 ， 如 果 该 文件 夹 存 在 ， 就 可 以 显示 出 该 文件 夹 包括 的 所 有 文件 ， 运 行 结果 如 图 4.34 所 示 。 


PALS 人 RIL 


目录 位 置 : 局 :Wanpp\htdocsWR\O5\010 提交 
人 
3: images 
4: index. php 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 4.34 遍历 指定 目录 下 的 所 有 文件 


图 关键 技术 


本 实例 实现 的 关键 是 目录 和 文件 处 理 函数 的 应 用 , 包括 file_existsO、is_dir0、opendir0 readdir0、 和 closedir0 
函数 。 

(1) file_exists0 函 数 ， 检 查 文件 或 目录 是 否 存在 ， 语 法 如 下 : 

bool file_ exists(string filename) 

如 果 由 filename 指定 的 文件 或 目录 存在 则 返回 TRUE， 和 否则 返回 FALSE。 

(2) is_dir0 函 数 ， 判 断 给 定 的 文件 名 是 否 是 一 个 目录 。 


bool is_dir(string filename) 
如 果 文 件 名 存在 并 且 为 目录 则 返回 TRUE。 如 果 fename 是 一 个 相对 路 径 ， 则 按照 当前 工作 目录 检查 其 相 
对 路 径 。 
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4 乓 注意 : 本 函数 的 结果 会 被 缓存 ; 本 函数 不 能 作用 于 远程 文件 ， 被 检查 的 文件 必须 通过 服务 器 的 文件 系统 
访问 。 

(3) opendir0 函 数 ， 打 开 目 录 句 柄 ， 语 法 如 下 : 

Tesource opendir ( string path) 

本 函数 返回 一 个 目录 句柄 ， 可 以 在 closedir0 和 readdir0 之 前 调用 。 如 果 path 不 是 一 个 合法 的 目录 或 者 因为 
权限 限制 或 文件 系统 错误 而 不 能 打开 目录 ，opendir0 返 回 FALSE 并 产生 一 个 错误 信息 。 

(4) readdir0 函 数 ， 从 目录 句柄 中 读 取 条 目 ， 语 法 如 下 : 

string readdir( resource dir handle) 

本 函数 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 在 文件 系统 中 的 排序 返回 。 

(5) closedir0 函 数 ， 关 闭 目录 句柄 ， 语 法 如 下 : 

String closedir( resource dir handle) 

本 函数 关闭 由 dir_handle 指定 的 目录 流 ， 目 录 流 必须 被 opendir0 打 开 过 。 
图 设计 过 程 

(1) 创建 ndex.php 文件 。 添 加 一 个 表单 ， 定 义 表单 元 素 ， 通 过 POST 方法 提交 目录 的 路 径 。 

(2) 在 index.php 中 ， 判 断 提交 的 目录 路 径 是 否 为 室 ， 如 果 不 为 空 ， 则 打开 目录 ， 读 取 目 录 中 的 文件 ， 并 
输出 读 取 到 的 文件 ， 关 闭 目录 ; 否则 ， 输 出 目录 不 存在 ， 其 关键 代码 如 下 : 


<?php 
if(!file_exists ( Slook file ){ /检测 指定 的 目录 是 否 存在 
print $look_file." 目 录 不 存在 !" : 
Jelse{ 
$i=0; 
if( is_dir ( $look file ){ // 检 测 是 否 是 合法 目录 
if ($list = opendir ( $look_file )){ /打开 目录 
while (Sread_list = readdir( $list )){ / 读 取 目录 
Sit+; 
echo " $i: ".iconv("gb2312","utf-8",$read_list)." <br> " ; /输出 目录 中 的 内 容 
} 
} 
closedir ( Slist ) ; /关闭 目录 
= 
秘笈 心 法 


心 法 领悟 233: 指定 目录 下 文件 的 读 取 、 操 作 。 
本 实例 只 是 可 以 浏览 到 指定 目录 下 包含 的 文件 , 不 可 以 对 文件 进行 操作 ， 有 关 如 何 操作 指定 目录 下 的 文件 ， 
将 在 后 面 的 实例 中 进行 讲解 。 


力 实例 说 明 


通过 对 网 站 目录 的 遍历 ， 能 够 更 快 地 了 解 网 站 的 结构 和 网 站 文件 的 存储 位 置 ， 通 过 对 文件 内 容 的 遍历 ， 能 
够 掌握 网 站 中 每 个 文件 的 作用 ;同时 也 便于 对 目录 和 文件 的 管理 。 本 实例 将 介绍 如 何 实现 目录 和 文件 的 遍历 以 
及 删除 。 运 行 本 实例 ， 如 图 4.35 所 示 。 
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图 4.35 遍历、 操作 指定 目录 下 的 所 有 文件 


关键 技术 


遍历 、 操 作 指 定 目 录 下 的 所 有 文件 的 关键 是 目录 、 文 件 处 理 函数 和 字符 串 处 理 函 数 的 综合 运用 
关键 的 目录 处 理 函 数 如 下 : 
(1) chdir0 函 数 ， 改 变 当 前 目录 ， 语 法 如 下 : 
bool chdir(string directory) 
参数 directory 用 于 指定 更 改 后 目录 的 位 置 。 操 作成 功 返 回 TRUE， 和 否则 返回 FALSE。 
(2) getewd0 函 数 ， 获 取 当 前 工作 的 目录 ， 语 法 如 下 : 
string getewd( void); 
(3) rmdir0 函 数 ， 删 除 目 录 ， 语 法 如 下 : 
bool rmdir ( string dirname ) 
尝试 删除 参数 dimame 所 指定 的 目录 。 该 目录 必须 是 空 的 ， 而 且 要 有 相应 的 权限 。 如 果 成 功 则 返回 TRUE， 
否则 返回 FALSE。 
在 对 文件 进行 操作 时 ， 主 要 应 用 到 如 下 几 个 函数 : 
(1) fopen0 函 数 、feets0 函 数 、readfile0 函 数 和 felose0 函 数 ， 有 关 这 4 个 函数 已 经 在 实例 232 和 实例 233 
中 介绍 过 ， 这 里 不 再 效 述 。 
(2) filectime0 函 数 ， 返 回 指定 文件 的 索引 节点 修改 时 间 ， 语 法 如 下 : 
int filectime(string filename): 
返回 文件 上 次 索引 节点 被 修改 的 时 间 ， 如 果 出 错 则 返回 FALSE。 时 间 以 UNIX 时 间 戳 的 方式 返回 。 
(3) filemtime() 函 数 ， 返 回 指定 文件 filename 的 最 后 修改 时 间 ， 语 法 如 下 : 
int filemtime(string filename); 
返回 文件 上 次 被 修改 的 时 间 ， 失 败 则 返回 FALSE。 时 间 以 UNIX 时 间 戳 的 方式 返回 。 
(4) unlink0 函 数 ， 删 除 文件 ， 语 法 如 下 : 
‘bool unlink ( string filename ) 
删除 由 字符 串 血 ename 指定 的 文件 。 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
在 完成 对 目录 和 文件 的 遍历 以 及 删除 过 程 中 ， 应 用 到 下 面 儿 个 字符 串 函 数 : 
(1) substr0 函 数 ， 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 ， 语 法 如 下 : 
string substr(string str.int startint length) 
substr0 函 数 的 参数 说 明 如 表 4.3 所 示 。 


表 4.3 substr() 函 数 的 参数 说 明 


参 数 说 有 明 
st | ”指定 字符 申 对 象 
start | 指定 开始 截取 字符 串 的 位 置 。 如 果 参 数 start 为 负数 ， 则 从 字符 目的 末尾 开始 截取 


length 可 选 参数 ， 指 定 截取 字符 的 个 数 ， 如 果 length 为 负数 ， 则 表示 取 到 倒数 第 length 个 字符 


331 


PHP 开发 实战 1200 例 (第 I 卷 ) 


说 明 : substrO 函 数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 1 个 字符 表示 为 0。 


(2) strpos0 函 数 ， 寻 找 字符 串 haystack 中 的 字符 needle 最 后 出 现 的 位 置 ， 语 法 如 下 : 


int strrpos(string haystack, char needle) 


参数 haystack 为 寻找 的 范围 ， 参 数 needle 为 寻找 的 字符 ， 其 中 needle 只 能 是 一 个 字符 ， 汉 字 不 可 以 。 如 果 


找 不 到 指定 的 字符 ， 则 返回 FALSE。 


(3) strtoupper0 函 数 ， 将 字符 串 str 全 部 转换 为 大 写字 符 串 ， 语 法 如 下 : 


string strtoupper(string str); 


(4) htmlentitiesO 函 数 ， 将 所 有 string 的 字符 都 转换 成 HTML 的 特殊 字 集 字符 串 ， 语 法 如 下 : 


string htmlentities(string string); 


图 设计 过 程 


(1) 创建 index.php 文件 。 应 用 目录 、 文 件 处 理 函 数 和 字符 串 处 理 函 数 完成 对 指定 目录 下 文件 的 读 取 操 作 ， 
并 设置 查看 文件 内 容 的 超 链接 和 删除 指定 文件 的 超 链接 。 在 设置 超 链接 的 参数 时 ， 应 用 urlencode0 函 数 对 字符 
串 进 行 编码 ， 其 完整 代码 请 参考 本 书 光盘 。 

(2) 创建 look_file.php 文件 ， 完 成 对 指定 文件 内 容 的 读 取 操作 ， 其 关键 代码 如 下 : 

a =iconv ( "utf-8", "gb2312", urldecode ( $_GET [catalog] ) ); 

Sfilename = iconv ( "utf-8", "gb2312", urldecode ( $_GET [filename] ) ); 


/ 苞 取 文件 的 信息 ， 设 置 编码 
/ 苞 取 文件 的 信息 ， 设 置 编码 


$type =iconv ( "utf-8", "gb2312", urldecode ( $_GET [type] )); 


/ 苞 取 文件 的 信息 ， 设 置 编码 


S$types = strtoupper ( $type ); // 完 成 字符 串 的 大 小 写 转换 
if ($types = ".PHP") { // 显 示 PHP 文件 的 内 容 
Sarr = file ( $catalog . "\\" . $filename ); // 读 取 文件 
foreach ( $arr as $value ) { /循环 输出 文件 内 容 
Svalue = htmlentities ( $value, ENT_COMPAT, "UTF-8" ); /| 特殊 字符 的 转换 
echo $value . "<br>"; /和 输出 内 容 
} else { 
S$tp=fopen ( $catalog . "\". $filename, "r" ); /显示 .txt 文 件 的 内 容 
while ( $line = fgets ( $fp ) ) { 
Sline = htmlentities ( $line, ENT_COMPAT. "GB2312" ); / 哇 殊 字符 的 转换 
echo iconv ( "gb2312", "utf-8", $line ): /内 出 文件 内 容 
felose ( $fp ); 
} 
> 
(3) 创建 delete.php 文件 ， 完 成 对 指定 文件 的 删除 操作 ， 代 码 请 参考 本 书 光盘 。 


力 秘笈 心 法 


心 法 领悟 234: 对 URL 字符 串 进 行 编码 的 重要 性 。 

在 通过 URL 传递 字符 串 参 数 时 ， 尽 量 应 用 urlencode0 函 数 对 传递 的 参数 值 进行 编码 ， 这 样 不 但 可 以 保证 传 
递 参数 值 的 安全 ， 而 且 可 以 防止 传递 的 参数 值 出 现 乱码 。 例 如 ， 本 实例 中 在 执行 指定 目录 、 文 件 的 删除 操作 时 ， 
在 执行 成 功 跳 转 到 上 级 页 面 时 ， 如 果 不 对 URL 传递 的 字符 串 参 数值 进行 编码 ， 那 么 就 不 能 够 完成 跳 转 的 操作 ， 
会 弹出 一 个 错误 提示 。 


会 话 应 用 


Ww COOKIE 
Wm SESSION 
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5.1 COOKIE 


在 Web 技术 发 展 的 历史 上 ，COOKIE 技术 的 出 现 是 一 个 重大 的 变革 。 最 先是 Netscape 公司 在 其 Netscape 
Navigator 浏览 器 中 引入 了 COOKIE 技术 ， 从 那 时 起 ，World Wide Web 协会 就 开始 支持 COOKIE 标准 。 以 后 又 
经 过 微软 公司 的 大 力 推广 ， 即 在 微软 公司 的 ntemet Explorer 浏览 器 中 完全 支持 COOKIE 技术 ， 到 现在 ， 绝 大 
多 数 浏览 器 都 支持 COOKIE 技术 ， 或 者 至 少 兼 容 COOKIE 技术 的 使 用 。 


图 实例 说 明 


COOKIE 是 在 HTTP 协议 下 ， 将 服务 器 传递 给 浏览 器 的 少量 数据 保存 到 用 户 浏览 器 的 一 种 方式 。 通 过 这 种 
方式 ， 即 使 在 浏览 器 被 关闭 和 连接 中 断 的 情况 下 ， 用 户 仍然 可 以 维护 状态 数据 。 本 实例 在 创建 和 读 取 COOKIE 
的 同时 ， 设 置 COOKIE 的 生命 周期 ， 实 现 控制 登录 用 户 的 过 期 时 间 。 运 行 结果 如 图 5.1 所 示 。 


: 


欢迎 mr 光临 ! 
GE -全 一 ‘ava 


图 5.1 控制 登录 用 户 的 过 期 时 间 


图 关键 技术 


(1) setcookie0 函 数 ， 设 置 COOKIE， 其 代码 如 下 : 
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, int secure]]]]]): 
该 函数 的 参数 说 明 如 表 5.1 所 示 。 


表 5.1 setcookie() 函 数 的 参数 说 明 

举例 
可 以 通过 $_COOKIE['cookiename 1] 调用 变量 名 为 
cookiename 的 COOKIE 


name ”|COOKIE 的 变量 名 


COOKIE 变量 的 值 ， 该 值 保存 在 客户 端 ， 不 能 用 来 保存 
敏感 数据 

COOKIE 的 过 期 时 间 , expire 是 标准 的 UNIX 时 间 标 记 , | 如 果 不 设置 COOKIE 的 过 期 时 间 , 那么 COOKIE 将 永远 
可 以 用 time0 函 数 或 mktime0 函 数 获取 ， 单 位 为 秒 有 效 ， 除 非 手 动 将 其 删除 

如 果 该 参数 设置 为 “/”， 则 它 在 整个 domain 内 有 效 ， 如 
果 设 置 为 “/5.1”, 它 在 domain 下 的 /5.1 目录 及 子 目录 内 
有 效 。 默 认 是 当前 目录 

如 果 要 使 COOKIE 在 mrbccd.cn 域名 下 的 所 有 子 域 都 有 
效 ， 应 该 设置 为 mrbccd.cn 

如 果 值 为 1， 则 COOKIE 只 能 在 HITPS 连接 上 有 效 ; 如 
果 值 为 默认 值 0， 则 在 HTTP 和 HTTPS 连接 上 均 有 效 


可 以 通过 $_COOKIE['values )] 获 取 名 为 values 的 值 


path COOKIE 在 服务 器 端的 有 效 路 径 


domain ”|COOKIE 有 效 的 域名 


secure ”| 指明 COOKIE 是 否 仅 通过 安全 的 HITPS， 值 为 0 或 1 
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(2) $_COOKIE: 经 由 HTTP Cookies 方法 提交 至 脚本 的 变量 ， 用 于 获取 COOKIE 变量 的 值 。 
图 设计 过 程 


(1) 创建 index.php 文件 ， 编 写 用 户 登 录 页 面 ， 将 用 户 登 录 信 息 提交 到 index_ok.php 文件 。 

(2) 创建 index_ok.php 文件 ， 获 取 表单 提交 的 用 户 登 录 信 息 ， 并 且 判 断 登录 的 用 户 名 和 密码 是 否 正 确 ， 如 
果 正 确 将 用 户 名 和 密码 赋 给 指定 的 COOKIE 变量 , 并 设置 COOKIE 的 过 期 时 间 ， 跳 转 到 cookie -php 页面 ; 否则 ， 
直接 给 出 提示 信息 ， 并 重新 跳 转 到 登录 页 ， 其 关键 代码 如 下 : 

<?php 


if($_POST['user]—"mr" &é& $ POST[pass]—"mrsoft"){ 1/ 判断 用 户 名 和 密码 是 否 正确 
setCookie("user",$_ POST[user]time0+60)or die(" 禁 止 cookie"); /创建 COOKIE 
setCookie("pass",$_POST['pass'],timeO+60)or die(" 禁 止 cookie"); /创建 COOKIE 


echo "<script>alert( 登 录 成 功 ! '); window.location href='cookie.php':</script>"; 

jelsef 

echo "<script>alert( 用 户 名 或 者 密码 不 正确 ! ): window.location href='index.php';</script>"; 
} 

?> 


(3) 创建 cookiephp 文件 ， 判 断 COOKIE 变量 的 值 是 否 存 在 ， 如 果 存 在 则 输出 本 页 内 容 ; 否则 ， 给 出 提 
示 信息 并 跳 转 到 登录 页 面 ， 其 关键 代码 如 下 : 


<?php 
is ES && $ COOKIE['pass]—"mrsoft"){ 
echo "欢迎 光临 ! 
jelsef 
echo "<script>alert(COOKIE 已 经 过 期 ， 请 重新 登录 ); window.location hre 人 -index.php':</script>"; 
} 


> 


力 秘笈 心 法 


心 法 领悟 255: 会 话 COOKIE 。 
如 果 不 设置 COOKIE 的 时 间 ， 就 表示 其 生命 周期 为 浏览 器 会 话 的 时 间 ， 只 要 关闭 正 浏览 器 ，COOKIE 就 
会 自动 消失 ， 这 种 COOKIE 被 称 为 会 话 COOKIE， 一 般 不 保存 在 硬盘 上 ， 而 是 保存 在 内 存 中 。 


力 实例 说 明 


所 谓 自动 登录 ， 即 用 户 第 一 次 成 功 登录 网 站 后 ， 在 一 段 时 间 内 ， 再 次 登录 该 
网 站 时 不 再 需要 填写 用 户 名 和 密码 ， 而 是 可 以 直接 进入 。 

运行 本 实例 ， 如 果 是 第 一 次 登录 ， 则 需要 填写 用 户 名 和 密码 才能 够 登录 。 如 
果 是 再 次 登录 ， 那么 就 不 需要 输入 用 户 名 和 密码 , 因为 $ COOKIE 会 人 COOKIE 。 E22 
中 读 取 这 些 信息 ， 用 户 直接 单 击 登录 按钮 即 可 。 登 录 成 功 后 进入 main php 页 面 ， 
运行 结果 如 图 5.2 所 示 。 


图 关键 技术 


本 功能 实现 的 关键 是 COOKIE 的 创建 、 过 期 时 间 的 设置 和 COOKIE 值 的 获取 。 其 中 创建 COOKIE 应 用 的 
是 setcookie0 函 数 ， 有 关 该 函数 的 的 应 用 、 过 期 时 间 的 设置 和 COOKIE 值 的 获取 请 参考 实例 255 中 的 关键 技术 ， 
这 里 不 再 袭 述 。 


游戏 登录 窗口 


5.2 进入 网 站 主页 
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设计 过 程 
(1) 创建 index.php 文件 ， 创 建 表单 ， 添 加 用 户 名 、 密 码 文 本 框 和 保存 时 间 选 择 单 选 按 钮 。 最 关键 的 是 编 


写 PHP 脚本 ， 通 过 $_ COOKIE 获取 COOKIE 中 存储 的 用 户 名 和 密码 数据 ， 并 将 其 作为 用 户 名 和 密码 的 默认 值 ， 
其 关键 代码 如 下 : 


<form id="form1" name="form1" method="post" action="index_ok.php"> 

<input id="lgname" name="name" value="<?php echo $ COOKIE['name']:?>" type="text" class="txt"/> 
<input id="lgpwd" name="pwd" value="<?php echo $ COOKIE[pwd1:?>" type="password" class="txt"/> 
<input name="times" type="radio" value="3600" checked="checked" />1 小 时 

<input type="radio" name="times" value="86400" />1 天 

<input type="image" name="imageField" src="images/dl gif" /> 

<input type="image" name="imageField2" onclick="form.resetO;return false;" src="images/cz.gif" /> 
</form> 


(2) 创建 index_ok.php 文件 ,通过 $_POST[] 方 法 获取 表单 中 提交 的 数据 ， 验 证 用 户 输入 的 用 户 名 和 密码 是 
否 正确 。 如 果 正 确 ， 则 通过 setcookie0 函 数 创建 COOKIE， 存 储 用 户 名 和 密码 ， 并 根据 表单 提交 的 时 间 设 置 
COOKIE 的 过 期 时 间 ， 并 跳 转 到 main php 页 面 ; 如 果 不 正确 ， 则 给 出 提示 信息 ， 并 跳 转 到 index.php 页 面 ， 其 
关键 代码 如 下 : 


<?php 
if(! empty($_POST [name] ) and ! empty ($_POST [pwd])){ / 测 断 用 户 名 和 密码 是 否 为 空 
if($_POST [name] 一 "mr" &&S POST [pwd'] — "mrsoft") { 
setcookie ( "name", $_ POST [name],time 0 +$_POST [times'] ); // 设 置 COOKIE 的 有 效 时 间 为 1 小 时 
setcookie ( "pwd", $ POST [pwd], time 0+S$ POST [times] ); // 设 置 COOKIE 的 有 效 时 间 为 1 小 时 
echo "<script>alert('succeed!');window.location.href="main.php':</script>"; 
}else{ 
echo "<script>alert( false!");window.location href="index.php':</script>"; 
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lse 
a "<script>alert(NULL):window.location. href=index. php';</script>"; 
} 
> 

(3) 创建 main.php 文件 ， 首 先 根据 $COOKIE 获取 的 COOKIE 值 判 断 用 户 是 否 具有 访问 权限 ， 如 果 有 则 
可 以 看 到 本 页 内 容 ， 否 则 将 给 出 提示 信息 ， 跳 转 到 index.php 页 面 ， 其 关键 代码 如 下 : 

<?php 
if($_COOKIE[name]—"™"){ /根据 COOKIE 的 值 ， 判 断 浏览 者 是 否 具有 访问 该 页 面 的 权限 
echo "<script>alert( 您 不 具有 访问 该 页 面 的 权限 ! "); window.location.href=index.php';</script>"; 
Jelse{ // 如 果 正 确 则 输出 主页 内 容 
> 


<!-- 省 略 了 HTML 内 容 --> 
> 


Fe 
也 笈 心 法 
心 法 领悟 236: COOKIE 的 优点 。 


在 使 用 COOKIE 时 ， 如 果 设 置 了 COOKIE 的 过 期 时 间 ， 浏 览 器 将 会 保存 COOKIE 数据 ， 即 使 用 户 重新 启 
动 计算 机 ， 只 要 没有 过 期 ,COOKIE 数据 就 一 直 有 效 。 


高 级 
趣味 指数 : 会 寅 寅 窗 ; 


国 实例 说 明 


现在 越 来 越 多 的 企业 、 个 人 喜欢 用 互联 网 来 进行 沟通 和 交流 ， 诸 如 留言 板 、 聊 天 室 、 论 坛 和 博客 等 交流 和 
展示 自己 的 方式 层出不穷 ， 而 且 一 个 企业 或 者 个 人 可 能 拥有 上 述 多 种 交流 方式 。 因 为 每 种 交流 方式 都 具有 自己 
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的 身份 验证 机 制 ， 这 样 势必 造成 如 果 某 位 用 户 要 以 会 员 的 身份 访问 网 站 ， 需 要 在 每 个 网 站 上 注册 ， 通 过 身份 验 
证 后 ， 才 能 以 会 员 的 身份 访问 网 站 。 即 使 用 户 以 同样 的 用 户 名 与 密码 在 每 个 网 站 上 注册 ， 这 样 虽然 可 以 避免 忘 
记 或 混淆 各 用 户 名 和 密码 ， 但 是 如 果 用 户 在 某 一 时 间 段 内 ， 需 访问 网 站 的 多 个 页 面 或 者 在 不 同 网 站 间 跳 转 ， 仍 
然 需要 登录 后 才能 以 会 员 的 身份 访问 网 站 的 话 ， 不 仅 给 用 户 带 来 了 不 便 ， 而 且 也 浪费 了 服务 器 的 空间 。 

如 果 所 有 的 网 站 能 够 实现 单 点 登录 ， 不 仅 在 用 户 体验 方面 有 所 提高 ， 而 且 真正 体现 了 集团 多 个 网 站 的 “ 兄 
弟 ” 性 。 通 过 这 种 有 机 结合 ， 不 但 便于 对 网 站 进行 管理 ， 而 且 能 更 好 地 体现 公司 大 平台 、 大 渠道 的 理念 。 同 时 ， 
这 样 做 也 利于 网 站 的 相互 促进 与 相互 宣传 。 

运行 本 实例 ， 如 果 是 第 一 次 登录 ， 那 么 将 进入 登录 页 面 ， 登 录 成 功 后 进入 博客 主页 ， 如 图 5.3 所 示 ; 单 击 
博客 主页 中 的 “我 的 论坛 ” 超 链 接 ， 将 以 此 用 户 身 份 直接 进入 论坛 系统 主页 ， 如 图 5.4 所 示 ; 同样 ， 单 击 论坛 
系统 主页 中 的 “博客 ” 超 链 接 可 以 跳 转 到 博客 主页 面 。 


(Bi ns 


出 自 《出 窗外 记 》 县 面 有 这 样 一 量 对 联 : 宠 后 不 属 ,得 应 前 花 开花 落 ; 去 留 无 香 , 所 天 空 云 关 云 好。 这 何洁 的 意 因 电 说 ， 为 人 做事 能 失守 奈 加 
太阳 秀平 寅 ， 才 能 不 壤 ; 视 职位 去 曾 如 云云 股 赤 幻 ， 才 能 无 意 。 规 在 的 人 大 多 多 得 活 得 很 累 ,不堪 重负 。 大 家 很 是 少 同 ， 力 什么 社会 在 
不 册 洪 步 ， 而 人 的 负荷 却 更 重 ,精神 进攻 证 ,后 想 异 罕 训 骂 。 拓 确 ,让 全 在 不 断 前 进 ， 也 页 加 文明 了 。 类 而 文明 社会 的 一 个 扯 点 就 是 造成 人 与 
目 帮 的 日 划分 局， 人 蓉 由 胡 竹 目 总 为 代价 ， 其 结果 全 是 陷于 世 作 名 摔 交 而 无 法 目 技 ， 反 到 于 外 在 8 去 导 物 和 而 不 知 什么 是 其 下 有 更。 金钱 并 
丁 - 权力 的 粉 争 、 帘 每 的 沉 译 让 人 更 心 湿 谍 。 是 非 、 成 了 、 得 失 让 人 可 喜 、 取 瑟 、 琶 障 ， 惑 沁 、 吏 居 或 避 ， 一 旦 所 让 法 凡 安 现 一旦 所 起 路 忆 
成 功 ， 一 号 荐 望 芒 空 左 也 形 ， 训 会 失 答 、 拓 总 乃至 失 志 。 失 竺 是 一 和 心理 失 商 ， 目 央 要 窜 失 等 的 精神 规 阳 米 丙 节 ; 闪 意 是 一 种 再 全 笠 ， 是 失 
落 的 情 庄 炒 与 深 齐 化 ; 失 志 则 是 一 种 心 鲜 失 册 ， 是 科 认 的 精 奈 ， 是 失落 、 失 赣 的 终 条 ， 而 要 灰 于 这 种 夫 落 、 失 间 ， 夫 让 衣 需要 窑 于 不 导 、 去 
漠 无 证。 一 幅 对 殿 ， 字 字数 语 ， 却 评 刘 者 出 了 人 生 对 事物 。 对 五 对 利 应 有 的 才 度 ; 榜 之 不 吝 、 从 之 不 居 、 庆 导 不 慨 、 志 留 无 总 。 这 笠 才 可 能 心 
卉 平和 ， 谱 泊 自 然 。 一 个 看 诗 前 三 字 ， 大 有 有 妇 泛 小 税 成 一 纺 ， 知 作 春 夏 与 交 信之 个 ， 而 盖 天 上 三 字 则 又 显示 了 放大 腿 光 ， 不 与 似 人 一 般 见识 的 情 
大 情 乓 ;一句 忆 卷 他 更 有 大 丈 赤 能 忆 能 促 的 业 遍 境界 ， 刁 落 付 并 的 下 以 物 喜 、 不 虽 书 塌 人 守 在 是 异 埋 癌 工 ， 更 精 有 次 亚 人 物 多 只 达 风 党 。 完 于 不 
迟 ， 去 汞 无 意 说 起 来 容易 ， 做 起 来 部 十 分 困难 。 


首页 登录 y 注册 


图 5.3 进入 博客 主页 面 


FANXING 网络 硬盘 设 为 首页 /加 入 收藏 联系 我 们 


首页 | 注册 登录 | 论坛 | 留言 
| 下 
可 长 目标 是 至 点 击 各 Ny TTA 
口 。 标题 位 置 放置 处 1110 3330 ~ 
而 外 联系 方式 
口 。 标题 位 置 航 轩 处 to 3330 和 i 
口 。 标题 位 置 训 屋外 Mio saa0 aw 
3: 硬 名 电子 图书 
口 标题 位 置 放 轩 处 Mio soo0 和 
口 。 标题 位 置 了 得 外 10 3330 NS a 
口 。 标题 位 置 放置 处 1110 3330 
口 标题 位 置 放置 处 Hi0 3330 
加 。 标题 位 置 放 叶 处 110 3330 
共有 2 页 ,当前 是 第 :页 EN TR 


图 5.4 进入 论坛 系统 主页 


图 关键 技术 

本 实例 开发 一 个 博客 网 站 和 一 个 论坛 网 站 ， 通 过 COOKIE 实现 单 击 登 录 的 功能 ， 即 无 论 在 博客 或 者 论坛 网 
站 中 ， 只 要 登录 后 ， 此 用 户 名 在 一 定时 间 内 ， 在 这 两 个 网 站 中 是 通用 的 。 

其 关键 就 是 对 COOKIE 值 的 判断 ， 如果 COOKIE 的 值 存在 并 且 与 数据 库 中 存储 的 值 相同 ， 那 么 就 可 以 实现 
不 同系 统 之 间 的 跳 转 ， 否 则 就 必须 先 登录 ， 才 可 以 访问 系统 中 的 内 容 ， 其 关键 代码 如 下 : 
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<?php 
include_once 'conn/conn php'; /执行 连接 数据 库 的 操作 
if($ COOKIEfnamel!="" and $ COORKIE[id]l!=""){ 
$sql = "select + from tb_login where name =".$ COOKIE[name]." and login id=".$ COOKIE[id]."™": 


$num = $conne->getRowsNum($sql); /返回 查询 结果 

Sconne->close_rst(); /关闭 数据 库 

这 $num != 0 or Snum {= "){ // 如 果 在 数据 表 存 在 该 记录 ， 则 直接 跳 转 到 登录 页 面 
header("Location: default.php"): 

Jelse{ // 否 则 输出 登录 页 面 的 内 容 


> 
<!-- 省 略 了 部 分 代码 -> 
<2php 
是 
Jelse{ 
/清除 数据 库 中 1 小 时 以 前 存储 的 用 户 登 录 数 据 ( 即 session 过 期 以 后 的 数据 ) 


Sdatetimes=mktime()-3600: /获取 1 小 时 前 的 时 间 入 
$sqls="delete from tb i Where datetime<".Sdatetimes."": /执行 删除 操作 
$nums = $conne->uidRst($sqls); /返回 查询 结果 
守 
<!- 省 略 了 部 分 代码 -> 
<2php } ?> 


图 设计 过 程 

这 里 以 博客 网 站 为 例 ， 讲 解 具体 的 操作 步 又 : 

(1) 创建 index.php 页 面 ， 添 加 用 户 登 录 的 表单 ， 将 登录 信息 提交 到 index_ok.php 页 面 中 。 在 index.php 页 
面 中 首先 连接 数据 库 ， 然 后 判断 COOKIE 的 值 是 否 为 空 ， 如 果 值 不 为 空 ， 并 且 在 指定 的 数据 表 中 存在 该 记录 
那么 将 直接 进入 网 站 的 主页 ， 不 必 进 行 登录 操作 ;如果 值 为 室 ， 则 输出 网 站 登录 页 面 ， 并 且 删 除 指定 数据 表 中 
已 经 过 期 的 用 户 登 录 信息 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 

(2) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 登录 信息 ， 完 成 登录 操作 。 单 击 登录 的 第 一 个 关键 点 : 将 
登录 成 功 的 用 户 名 和 Session ID 值 保存 到 COOKIE 中 ,设置 COOKIE 的 过 期 时 间 为 1 小 时 ， 有 效 范围 是 服务 器 
的 根 目录 ; 单 点 登录 的 第 二 个 关键 点 : 将 登录 的 用 户 名 和 Session ID 值 存储 到 一 个 数据 表 中 。 此 COOKIE 值 和 
数据 表 中 的 数据 是 验证 当前 用 户 是 否 具 有 单 点 登录 权限 的 唯一 依据 ， 代 码 如 下 : 


<?php 

session start(); 

include_once 'conn/conn.php'; /| 执行 连接 数据 库 的 操作 
$name = addslashes($_POST['name’]): /获取 用 户 名 
S$pwd=S$_POST[pwd]; /获取 密码 


if(!empty($name) and !empty(Spwd)){ 
$sql = "select * from tb member Where name = ".$name.” and password =".$pwd."™; 


Snum = $conne->getRowsNum($sql); /返回 查询 结果 

S$conne->close rst0; /局 放 查询 结果 

这 $num — 0 or $num — "){ 7/ 如果 不 正确 
echo "<script>alert( 用 户 名 和 密码 不 正确 ! ): window.location.href='index.php';</script>"; 

jelse{ /如 果 正 确 ， 则 将 登录 用 户 名 数据 存储 到 COOKIE 中 
Ssession id-session id0: /获取 SESSION ID 
setcookie("name", $name, time0+3600. "/"); /创建 COORIE 


setcookie("id", mds(Ssession id). time0+3600. "/"); ” // 创 建 COOKIE 
$sqls="insert into tb_login(name,login_id.datetime)values(".$name.".".md5($session_ id).™",".mktime(Q.")"; $nums = $conne->uidRst($sqls): 
/上 返回 查询 结果 
echo "<script>alert( 登 录 成 功 ! "); window.location.href='default.php':</script>": 


} 
> 
(3) 创建 defaultphp 网 站 主页 面 。 其 关键 就 是 根据 COOKIE 值 和 指定 数据 表 中 存储 的 数据 判断 当前 用 户 
是 否 具有 访问 主页 的 权限 ， 如 果 有 则 输出 网 站 主页 的 内 容 ， 否 则 将 跳 转 到 登录 页 面 ， 代 码 如 下 : 
oar !=" and $_ COORIE[id]!="){ 


include_once ‘conn/conn.php'; /| 执行 连接 数据 库 的 操作 
$sql = "select * from tb_login where name =".$ COOKIE[name]." and login id=".$ COOKIE[id].”": 


第 5 章 会 话 应 用 
S$num = $conne->getRowsNum($sq]): /返回 查询 结果 
S$conne->close rst0: /关闭 数据 库 
这 Snoum 一 0orSnum 一 "){ 
"Location: index.php"); 
jelsef 


> 
/省 略 了 主页 面 代码 ! 

¥ 
Jelse{ 

header("Location: index.php"); 
} 


> 


(4) 在 com 文件 夹 下 创建 conn.php 文件 ， 实 现 连接 数据 库 的 操作 。 
图 秘笈 心 法 
心 法 领悟 237: 单 击 登录 的 注意 事项 。 
如 果 当 前 用 户 手 动 清除 了 客户 端 COOKIE 的 信息 ， 那 么 本 实例 的 功能 就 会 失效 ， 需 要 重新 登录 ; 如 果 当 前 
用 户 的 客户 端 禁止 了 COOKIE 功能 的 使 用 ， 那 么 本 实例 就 不 能 实现 单 击 登录 的 效果 。 


高 级 


实例 258 | hk 


i 
i 
上 
a 


力 实例 说 明 


所 谓 用 户 在 线 时 间 是 指 从 用 户 登 录 到 页 面 开始 ， 到 关闭 浏览 器 为 止 的 时 间 ， 而 COOKIE 的 生命 周期 在 默认 
情况 下 关闭 浏览 器 时 自动 删除 ， 这 非常 符合 在 线 统计 时 间 的 特点 ， 是 很 多 服务 类 网 站 优先 选择 的 统计 手段 。 

本 实例 通过 创建 COOKIE， 保 存 用 户 登 录 到 页 面 的 时 间 戳 ， 在 用 户 单 击 退 出 按钮 时 计算 用 户 在 线 时 间 。 运 
行 结果 如 图 5.5 所 示 。 


在 线 时 间 : 00:01:43 黎 ! 
您 的 IP 地 址 :192.168.1.59 
您 的 机 器 名 称 : pkh 


te 


图 5.5 统计 用 户 的 在 线 时 间 
图 关键 技术 
本 实例 的 关键 点 是 通过 创建 COOKIE 保存 用 户 登录 到 页 面 的 时 间 戳 并 与 结束 时 间 改 做 减法 运算 。 
用 户 登 录 时 间 : 
RE 
setcookie(times’, Sstr): 
用 户 退 出 时 间 : 
Sstring = timeO-$_COORIE['times']: 
echo "在 线 时 间 : ".date("H:i:s",$string)." 秒 ! "."<br>"; 
图 设计 过 程 
(1) 沿用 实例 257 的 Forum 系统 ， 在 index.php 文件 中 创建 COOKIE， 存 储 用 户 的 登录 时 间 惟 ， 其 关键 代 
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码 如 下 : 


<?php 
include_once ‘conn/conn.php'; /| 执行 连 接 数据 库 的 操作 
$str = timeO; 
setcookie('times', $str); 
if($_COOKIE[name]!="" and $ COOKIE[id]!="){ 
$sql = "select * from tb login where name =".$ COOKIE[name]." and login id=".$ COOKIE[id]."™: 


Snum = $conne->getRowsNum($sql):; // 返 回 查 询 结 果 
Sconne->close_rst|); // 关 闭 数据 库 
这 $num != 0 or Snum {= "){ 

header("Location: default.php"): 
jelsef 


2) 创建 information.php 文件 ， 应 用 系统 的 当前 时 间 戳 减 去 COOKIE 中 存储 的 登录 时 间 戳 ， 即 获取 到 系 
统 在 线 时 间 的 时 间 惟 ,并 通过 dateO 函 数 对 这 个 时 间 戳 进行 格式 化 ,输出 用 户 的 在 线 时 间 ， 同 时 输出 登录 用 户 的 
卫 和 机 器 名 称 ， 其 关键 代码 如 下 : 
be Sstring = time()-$ COOKIEP'times']; 
echo "在 线 时 间 : ".date("H:i:s"， ,Sstring)" 秒 1 " <br>"; 
echo "您 的 他 地 址 :".getenv(REMOTE_ADDR”)."<br>"; 


echo "您 的 机 器 名 称 : ".gethostbyaddr(getenv(REMOTE_ADDR)); 
> 


图 秘笈 心 法 


心 法 领悟 238: COOKIE 会 一 直 伴 随 网 站 中 的 每 个 请 求 ， 直 到 过 期 为 止 。 
浏览 器 创建 一 个 COOKIE 后 ， 对 于 每 一 个 针对 该 网 站 的 请 求 ， 都 会 在 Header 中 带 有 这 个 COOKIE， 而 且 
浏览 器 会 一 直 发 送 ， 直 到 COOKIE 过 期 为 止 。 不 过 ， 对 于 其 他 网 站 的 请 求 ，COOKIE 不 会 一 起 发 送 。 


趣味 指数 : 会 傅 傅 傅 | 


力 实例 说 明 


默认 情况 下 ，COOKIE 的 生命 周期 是 以 关闭 浏览 器 为 基准 的 ， 也 就 是 说 如 果 用 户 不 关闭 浏览 器 并 且 没有 对 
COOKIE 进行 设置 ，COOKIE 永远 也 不 会 过 期 失效 。 假 如 用 户 在 互联 网 发 布 的 网 站 有 成 百 上 千 的 用 户 浏览 ， 
并 且 在 线 浏 览 用 户 数量 一 直 增 加 ， 如 果 不 对 用 户 访问 网 站 的 时 间 进 行 限制 ， 结 果 只 能 是 服务 器 资源 耗 尽 ， 网 站 
瘫痪 。 

本 实例 通过 设置 COOKIE 限制 用 户 访问 网 站 的 时 间 ， 运 行 结 果 如 图 5.6 和 图 5.7 所 示 。 


FANXING mn sar, eeu /ms 


- re 
i 您 访问 网 站 的 时 间 到 了 ! 
图 5.6 COOKIE 未 失效 ， 访 问 网 站 图 5.7 COOKIE 失效 


第 5 章 会 话 应 用 


力 关键 技术 

本 实例 的 关键 点 是 通过 setcookie0 函 数 创建 COOKIE 并 设置 COOKIE 的 有 效 时 间 .然后 , 通过 判断 COOKIE 
变量 是 否 存在 和 COOKIE 变量 的 值 是 否 为 空 来 控制 用 户 访问 网 站 的 时 间 ， 其 关键 代码 如 下 : 

<?php 


session_startO: /初始 化 SESSION 变量 
Ssession id-session id0; /获取 Session_ID 
setcookie("start",$session id.timeO+10): /定义 COOKIE 变量 ， 设 置 COOKIE 的 有 效 时 间 是 10 秒 
> 
图 设计 过 程 


(1) 创建 index.php 文件 。 首 先 ， 初 始 化 SESSION 变量 ， 获 取 SESSION_ID， 然 后 ， 通 过 setcookieO 函 数 
创建 COOKIE， 并 将 SESSION ID 作为 COOKIE 值 ， 同 时 设置 COOKIE 的 有 效 时 间 为 10 秒 。 

(2) 最 后 ， 在 页 面 中 通过 判断 COOKIE 变量 的 值 是 否 为 空 来 限制 用 户 访问 网 站 的 时 间 ， 其 关键 代码 如 下 : 

?php 

Hes coomzteaml $_ COOKIE['start] 一 $session id){ 

.省略 了 网 页 中 的 代码 

<?php 

jslsef 

echo "<hl style ='color:red;> 您 访问 网 站 的 时 间 到 了 </h1>"; 

} 


> 


图 秘笈 心 法 


心 法 领悟 259: 使 用 COOKIE 存在 隐患 。 


COOKIE 是 以 一 种 客户 端 明文 文件 的 方式 存储 的 ， 这 样 会 涉及 到 一 个 安全 问题 ， 所 以 在 使 用 COOKIE 保留 
用 户 资料 时 CGI 会 有 一 个 加 密 过 程 。 


图 实例 说 明 

COOKIE 是 用 来 解决 HITP Web 协议 无 状态 的 问题 的 ， 可 以 作为 一 种 暂时 性 的 短信 息 存储 器 ， 存 储 变量 值 
或 者 属性 ， 其 最 主要 的 应 用 是 保存 客户 信息 ， 例 如 用 户 名 、 密 码 、 联 系 方式 、 家 庭 住址 等 。 

本 实例 实现 用 户 注册 的 功能 ， 并 通过 COOKIE 获取 用 户 注册 的 用 户 名 、 密 码 ， 其 运行 结果 如 图 5.8 所 示 。 


用 PS: 
rrr77 
wes: M53e 
| 

多 

、\ ki 人 


图 5.8 ”用 户 注册 时 客户 端 获 取 的 COOKIE 数据 
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图 关键 技术 


本 实例 实现 简单 的 用 户 注册 功能 ， 其 关键 是 运用 setcookie0 函 数 创建 COOKIE 变量 ， 将 用 户 的 注册 信息 存 
储 到 客户 端 ， 客 户 端 COOKIE 的 数据 存储 于 如 图 5.9 所 示 的 文件 中 。 


全 Clocee ent= ond Settineg=VkduinictratozVLacal Sottis6r M7 7 1 
EE 


BE c ecmeats eed Settiacs Wninistr er Uoed Settires\T arorrr Interret Miles 


图 5.9 客户 端 生成 的 COOKIE 文件 


通过 setcookie0 函 数 创 建 COOKIE， 存 储 用 户 名 和 密码 ， 并 设置 密码 的 有 效 时 间 。 最 后 ， 通 过 自动 全 局 变 
量 $_COOKIE 获取 并 输出 COOKIE 变量 中 存储 的 数据 。 
力 设计 过 程 
(1) 创建 index.php 文件 ， 添 加 表单 、 表 单元 素 ， 完 成 用 户 注册 页 面 的 设计 。 同 时 能 够 对 提交 的 用 户 名 进 
行 检测 ， 对 验证 码 进行 刷新 操作 ， 其 关键 代码 如 下 : 
<form name="forml" method="post" action="index_ok.php"> 
<input name="name" type="text" value="<?php echo $ COOKIE['name']:?>" size="15"> 
<input name="check" type="submit" id="check" value=" 检 测 " /> 
<input name="pwd" type="password" size="15" value="<?php echo $ COOKIE[pwd]:?>" /> 
<input name="ym" type="text" size="5"> 
?php 


Samay= amTay(1 =>"pic/1.ipg",2 =>"pic/2.ipg",3 =>"pic/3.jpg",4 =>"pic/4.ipg",5 =>"pic/S.jpg' 


for($a = 0;$a < 4;$at+){ /招行 起 入 下 ， 获取 数组 中 的 图 片 数 据 
; Srand = Tand(1,5)."&nbsp;"; /获取 随机 数据 
Srands = explode("&nbsp;",Srand); /通过 &nbsp 分 割 字符 串 
Srande = implode($rands); // 读 取 数 组 中 的 数据 ， 返 回 一 个 字符 串 
$_SESSION['ym']=$rande:; // 将 字符 串 赋 给 SESSION 变量 
for($b= 0:$b < 4:$b++){ // 执 行 for 循环 
echo "<img src=pic/".Srands[Sb]."jpg>"; /输出 验证 码 图 像 
> 
<a href='index.php 人 > 刷新 </a> 
<br><br> 


&nbsp:&nbsp:<input type="submit" name="sub" value=" 注 册 " /> 

&nbsp:&nbsp:<input type="reset" name="res" value=" 重 置 " /> 

</form> 

(2) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 完 成 用 户 注册 的 操作 。 首 先 ， 初 始 化 SESSION 变 
量 ， 连接 数据 库 。 然后 ， 对 表单 中 提交 的 数据 进行 判断 ， 判 断 用 户 注册 信息 是 否 为 空 及 用 户 名 是 否 被 占用 。 最 
后 ， 执 行 insert 添加 语句 ， 将 用 户 注册 的 信息 添加 到 数据 表 中 ， 并 且 通 过 setcookieO 函 数 创建 COOKIE 变量 存 
储 用 户 名 和 密码 。index_ok.php 的 关键 代码 如 下 : 

if($_POST [sub]){ // 浏 断 按钮 的 值 ， 执 行 不 同 的 操作 


if($_POST [name] —""||$_POST [pwd]—""||$_POST [ym] —"") { 1/ 判断 注册 信息 是 否 为 空 
echo "<script>alert( 注 册 信息 不 能 为 室 ");location href~'index.php'</script>"; 
} 


$sql = "SELECT * FROM tb form where name=".S$_POST[mame]."": /定义 查询 语句 
Srs = mysql_query ( $sql. $conn ): /执行 查询 操作 
Sresult=mysql_num rows($rs): /获取 查询 结果 
if($result>0){ // 如 果 查 询 结果 大 于 0 说 明 用 户 名 被 占用 


echo "<script>alert( 用 户 名 被 占用 人 ):location href='index.php':</script>": 


} 
if($_POST [ym']—$_SESSION[ym'D) { /判断 验证 码 是 否 正确 
mysql_query ( "INSERT INTO tb form(name.pwd.last_date) VALUES(".$ POST [name'].".".$_POST[pwd].".nowO)" ): 
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setcookie(‘name'.$_POST [name]): /创建 COOKIE 变量 
setcookie(‘pwd'.$_POST[pwd].timeQ+60): /| 创建 COOKIE， 设 置 过 期 时 间 
echo "<script>alert( 注 册 成 功 ):window.location href='main.php':</script>"; 

}else { 


echo "<scripf>alert( 验 证 码 错误 ):window.location href='index.php':</script>"; 
} 
} 


(3) 创建 main.php 文件 ， 注 册 成 功 后 通过 $_COOKIE 全 局 变量 获取 COOKIE 中 存储 的 用 户 名 和 密码 ，: 
关键 代码 如 下 : 


?php 

echo "用 户 名 : "$_COORKIE[mame]."<br>"; 
echo " 密 &nbsp:&nbsp: 码 : ". $_COOKIE['pwd]; 
> 


(4) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 服务 器 和 db_database05 数据 库 的 连接 。 
也 笈 心 法 


心 法 领悟 260: COOKIE 文件 命名 。 
COOKIE 的 概念 最 早 是 由 Netscape 在 1994 年 提出 来 的 ， 是 指 保存 在 浏览 器 中 的 小 信息 包 。 更 确切 地 说 ， 


多 


COOKIE 是 保存 在 用 户 硬盘 上 的 由 字符 串 组 成 的 小 文本 文件 。 


文本 文件 的 命令 格式 如 下 : 
用 户 名 @ 网 站 地 址 [数字 ].txt 


高 级 


my 
基本 上 人 全 二 * | 


图 实例 说 明 


COOKIE 具有 一 定 的 时 效 性 ， 当 超过 其 生命 周期 后 即 失效 。 但 是 ， 如 果 COOKIE 没有 超过 其 生命 周期 ， 那 
么 它 存储 在 客户 端的 数据 就 有 可 能 被 盗 取 。 所 以 ， 为 保护 信息 资源 ， 防 止 不 法 用 户 破译 ， 用 户 可 以 在 关闭 浏览 
器 之 前 ， 通 过 程序 自动 删除 存储 在 客户 端的 COOKIE。 本 实例 通过 setcookie0 函 数 实现 删除 客户 端 COOKIE 的 
功能 ， 其 运行 结果 如 图 5.10 所 示 。 
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5.10 ”删除 客户 端的 COOKIE 


aoooooB 


图 关键 技术 


本 实例 运用 setcookieO 函 数 的 第 3 个 参数 值 ， 完 成 客户 端 COOKIE 的 删除 操作 。 因 为 setcookieO 函 数 的 第 3 
个 参数 是 用 来 设置 COOKIE 的 有 效 时 间 的 , 所 以 如 果 设 置 一 个 小 于 系统 当前 时 间 的 有 效 期 , 那么 COOKIE 就 已 
经 过 期 ， 也 就 完成 了 客户 端 COOKIE 的 删除 操作 ， 其 关键 代码 如 下 : 


setcookie("name",",timeO-1): 


这 里 设置 COOKIE 的 有 效 期 使 用 的 是 time0 函 数 ， 即 系统 当前 的 时 间 惟 ， 而 具体 的 有 效 期 值 是 timeO-1。 
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力 设计 过 程 

(1) 创建 index.php 文件 , 编写 用 户 登录 页 面 ,并 在 本 页 获取 用 户 的 登录 信息 ， 同 时 通过 setcookieO 函 数 将 
用 户 登 录 信息 存储 到 COOKIE 中 ， 并 且 根 据 表单 中 提交 的 值 设置 它们 的 有 效 期 ， 其 关键 代码 如 下 : 

<?php 


setcookie("usemame"."$_POST[name]".(timeQ+$_POST[check])): 1/ 创建 用 户 名 的 COOKIE 变量 
setcookie("pwd","$_POST[pwd]".(timeO+$_POST[check]D)); // 创 建 密码 COOKIE 变量 
setcookie("IP",$_SERVER[REMOTE ADDR'].(time0+S POST[check])): // 创 建 用 户 他 地 址 COOKIE 变量 
> 


2) 创建 main.php 文件 ， 设 计 网 站 的 主页 。 首 先 ， 判 断 COOKIE 变量 的 值 是 否 为 室 ， 如 果 不 为 空 则 可 以 
访问 本 页 的 内 容 ， 否 则 将 给 出 提示 信息 ， 并 跳 转 到 登录 页 面 。 然 后 ,在 本 页 设置 删除 客户 端 COOKIE 的 超 链接 ， 
当 单 击 “ 删 除 COORIE ”图 片 链接 时 ， 将 跳 转 到 本 页 ， 在 本 页 中 通过 setcookieO 函 数 重 新 设置 COOKIE 的 过 期 
时 间 为 ttme0-1， 以 删除 客户 端的 COOKIE， 其 关键 代码 如 下 : 

<?php 

这 $_COORKIE[usemame]'="" &&$ COOKIE[pwd]!=""){ 

iflisset($ GET[cookieD)f 

Setcooki "timeO-1); 

setcookie("pwd","",timeO-1); 

setcookie("IP","",time()-1); 

echo "<script>alert(COOKIE 已 删除 ， 确 认 退 出 ? ):location href='index.php'</script>"; 
} 


es 
图 秘笈 心 法 
心 法 领悟 261: COOKIE 的 时 效 性 。 


在 编程 领域 , 程序 员 更 倾向 于 COOKIE 的 时 效 性 而 不 是 其 保存 信息 的 特性 。 因为 COOKIE 以 明文 方式 保存 
信息 ， 为 了 安全 起 见 ， 程 序 员 更 喜欢 用 服务 器 端的 SESSION 机 制 来 保存 信息 。 


COOKIE 高 级 | 
趣味 指数 : 食 全 全 雁 


实例 262 


国 实例 说 明 


有 很 多 用 户 提出 在 自己 硬盘 上 保存 不 明 数 据 会 带 来 安全 隐患 ， 所 以 用 户 可 以 关闭 COOKIE 功能 ， 并 且 从 硬 
盘 上 删除 COOKIE。 以 正 浏览 器 为 例 ， 可 以 选择 “工具 ”菜单 中 的 “Intemet 选项 ”命令 ， 在 弹出 的 对 话 框 中 
直接 删除 COOKIE 文件 ， 如 图 5.11 所 示 。 
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图 5.11 删除 COOKIE 
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图 关键 技术 


本 实例 的 关键 点 是 如 何在 客户 端 对 COOKIJE 进行 控制 ， 其 具体 的 操作 方法 如 下 : 
以 正 浏 览 器 为 例 ， 选 择 “ 工 具 ” 菜 单 中 的 “Internet 选项 ”命令 ， 在 弹出 的 对 话 框 中 选择 “隐私 ”选项 卡 ， 
拖 动 隐私 设置 级 别 滑 块 ， 根 据 提 示 设 定 想 要 的 隐私 级 别 ， 如 图 5.12 所 示 : 
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图 5.12 阻止 所 有 COOKIE 


图 设计 过 程 

这 里 仍然 运用 实例 260 的 内 容 ， 在 用 户 注 册 成 功 后 通过 COOKIE 变量 获取 用 户 的 注册 信息 。 在 本 实例 中 ， 
调整 客户 端 COOKIE 的 控制 权限 (方法 参见 关键 技术 )，, 然后 运行 实例 260 的 内 容 , 测试 在 客户 端 禁 止 COOKIE 
的 情况 下 ， 是 否 可 以 获取 用 户 注册 成 功 后 COOKIE 变量 中 存储 的 用 户 注册 信息 。 

本 实例 的 实现 步骤 请 读者 参考 实例 260， 其 完整 代码 请 参考 本 书 光盘 ， 这 里 不 再 歼 述 。 
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心 法 领悟 262: 使 用 COOKIE 的 注意 事项 。 

(1) 在 应 用 setcookie0 函 数 之 前 ， 不 能 有 任何 HTML 输出 ， 如 果 用 户 犯 了 这 个 错误 ， 那 么 结果 可 想 而 知 ， 
随 之 而 来 的 肯定 是 一 堆 错 误 代码 。 切 记 ， 即 使 是 空格 、 空 行 也 不 可 以 。 

(2) 通过 setcookie0 函 数 创建 COOKIE 后 , 在 当前 页 应 用 echo 语句 输出 $8 _COOKIE[] 时 , 不 会 有 任何 输出 。 
必须 在 刷新 后 或 者 到 达 下 一 个 页 面 才 可 以 看 到 COOKIE 的 值 ， 因 为 setcookie0 函 数 执行 后 ， 会 向 客户 端 发 送 一 
个 COOKIE， 如 果 不 刷 新 或 者 浏览 下 一 个 页 面 ， 客 户 端 就 不 能 将 COOKIE 送 回 。 

(3) 一 个 浏览 器 最 多 能 创建 30 个 COOKIE， 并 且 每 个 COOKIE 的 容量 不 能 超过 4KB; 每 个 Web 站 点 能 
设置 的 COOKIE 总 数 不 能 超过 20 个 。 


5.2 SESSION 


SESSION 又 被 称 为 会 话 ， 是 指 用 户 访问 Web 站 点 时 的 一 系列 动作 。PHP 提供 管理 会 话 的 机 制 ， 可 以 追踪 
到 用 户 在 这 一 时 期 的 动作 ， 显 示 出 用 户 喜 欢 什么 、 需 要 什么 等 。 与 COOKIE 相 比 ， 会 话 更 加 强大 ， 不 但 能 够 管 
理 大 量 数据 ， 而 且 可 以 将 信息 保存 在 服务 器 端 ， 相 对 更 安全 ， 并 且 没 有 存储 长 度 的 限制 。 
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实例 263 a 


趣味 指数 : 便便 凋 衣 


图 实例 说 明 


在 论坛 中 ， 如 果 是 管理 员 ， 则 可 以 发 布 公告 信息 ， 如 果 是 普通 用 户 ， 则 不 可 以 。 那 么 程序 是 如 何 对 登录 用 
户 的 权限 进行 判断 的 呢 ? 这 就 是 本 实例 将 要 向 大 家 介绍 的 技术 , 即 通过 SESSION 变量 掌控 登录 用 户 的 权限 。 如 
果 是 管理 员 登 录 , 则 可 以 添加 公告 信息 ， 而 如 果 是 普通 用 户 ， 则 只 可 以 浏览 论坛 中 的 帖子 ， 其 运行 结果 如 图 5.13 
和 图 5.14 所 示 。 
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图 5.13 管理 员 登 录 图 5.14 发 布 留言 


如 图 5.14 所 示 ， 以 管理 员 身 份 登录 到 main .php 主页 后 ， 可 以 单 击 “ 留 言 ” 超 链接 ， 发 布 留言 信息 ， 如 果 是 
以 普通 用 户 身 份 登录 ， 那 么 在 main.php 主页 中 ，“ 留 言 ” 超 链 接 是 不 可 用 的 ， 因 为 普通 用 户 不 具备 发 布 留言 的 
权限 。 


图 关键 技术 


(1) 应 用 SESSION， 首先 要 初始 化 SESSION 变量 ， 使 用 的 是 session_start0 函 数 ， 其 语法 如 下 : 


bool session_start ( void ); 

该 函数 判断 是 否 有 一 个 会 话 ID 存在 ， 如 果 不 存在 ， 就 创建 一 个 : 如 果 存 在 ， 则 将 这 个 已 注册 的 会 话 变量 载 
入 以 供 使 用 。 

(2) 创建 SESSION 变量 ， 应 用 预定 义 变量 $_ SESSION[]， 其 应 用 语法 如 下 : 


$_SESSION["name"] = "value"; 
通过 预定 义 变量 $_SESSION[] 定 义 SESSION 变量 , "name" 表 示 设 置 变量 的 名 称 , "value" 表 示 设 置 变量 的 值 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 添 加 表单 ， 设 计 用 户 登 录 页 面 ， 并 获取 表单 提交 的 用 户 名 和 密码 ， 在 本 页 中 对 
用 户 提交 的 数据 进行 判断 。 首 先 ， 初 始 化 SESSION 变量 ,判断 用 户 提交 的 值 是 否 为 空 ， 若 不 为 空 ， 判 断 用 户 登 
录 身 份 ， 如 果 是 管理 员 则 为 SESSION 变量 type 赋值 0， 如 果 为 普通 用 户 则 为 SESSION 变量 type 赋值 1， 其 关 


键 代码 如 下 : 
<2php 
session_start(); 
if($ POST[sub1 一 tmue)f 
if($_POST['user]!="" && $ POST[pwd]'=""){ // 浏 断 用 户 名 和 密码 是 否 为 空 
if($_POST['user]—"mr" && $ POST[pwd] 一 "mrsoftD{ /判断 是 否 是 管理 员 


$_SESSION['type] = 0: // 为 SESSION 变量 赋值 0 
echo "<script>alert( 管 理 员 登录 成 功 ! "); window.location href='main php':</script>"; 
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jelsef 
$_SESSION['type] = 1 1/ 如果 不 是 管理 员 ， 为 SESSION 变量 赋值 1 
echo "<script>alert( 用 户 名 登录 成 功 ! "): window.location.href='main.php':</script>"; 
} 
$_SESSION['user] =$_POST[user]: // 将 登录 用 户 名 存储 到 SESSION 变量 user 中 
$_SESSION['pwd] = $_ POST[pwd']: /将 登录 密码 存储 到 SESSION 变量 pwd 中 
jelsef 


echo "<scripf>alert( 用 户 名 和 密码 不 能 为 室 ! ); window-location href='index.php';</script>"; 


> 

(2) 创建 main.php 文件 ， 编 写 网 站 的 主页 面 。 首 先 ， 初 始 化 SESSION 变量 。 然 后 ， 根 据 SESSION 变量 
type 的 值 定义 页 面 的 输出 内 容 ， 如 果 SESSION 变量 的 值 为 0， 则 说 明 登 录用 户 是 管理 员 ， 那 么 具备 发 布 公告 的 
权限 ， 如果 SESSION 变量 的 值 为 1， 则 说 明 登 录用 户 是 普通 用 户 ， 那 么 就 不 具备 发 布 公告 的 权限 ， 即 控制 发 布 
公告 的 超 链接 不 输出 ， 其 关键 代码 如 下 : 

<?php 


session_startO; /初始 化 SESSION 变量 
> 
<?php 
if($_SESSION['type]—"0"){ /根据 SESSION 变量 type 的 值 决定 是 否 输出 发 布 公告 的 超 链接 
> 
<area shape="rect" coords="330,64,385,100" href="mes.php" /> 
<php 


?> 

(3) 创建 mes.php 文件 ， 编 写 发 布 公告 信息 的 页 面 ， 根 据 SESSION 变量 type 的 值 决定 用 户 是 否 具 有 访问 
此 页 面 的 权限 。 
图 秘笈 心 法 

心 法 领悟 263: SESSION 的 生命 周期 。 

SESSION 的 生命 周期 是 指 从 用 户 访问 页 面 开始 到 断 开 与 网 站 的 连接 为 止 。 在 用 户 每 一 次 连接 时 ，PHP 都 会 
自动 生成 一 个 唯一 的 SESSION ID 以 标识 当前 用 户 与 其 他 用 户 。 

高 级 
趣味 指数 ; kototof| 


图 实例 说 明 


计数 器 用 来 统计 一 个 网 站 被 访问 的 次 数 ， 体 现 了 一 个 网 站 受 关注 的 程度 。 本 实例 将 向 大 家 介绍 如 何 制 作 计 
数 器 ， 以 及 如 何 屏 蔽 刷新 页 面 对 计 数 器 的 影响 。 在 本 实例 中 ， 当 用 户 访问 页 面 时 计数 器 的 值 会 增加 一 次 ， 但 是 
无 论 如 何 刷新 页 面 , 计数 器 的 值 都 不 会 再 次 增加 , 只 有 重新 打开 页 面 才 会 发 生变 化 , 本 实例 的 运行 结果 如 图 5.15 
所 示 。 

避 站 锣 访 癌症 :73 


图 5.15 SESSION 变量 屏蔽 页 面 刷新 对 计数 器 的 影响 


力 关键 技术 


SESSION 变量 控制 重复 计数 的 原理 如 下 : 在 当前 页 面 被 访问 时 , 初始 化 一 个 SESSION 变量 , 判断 SESSION 
变量 的 值 是 否 为 室 ， 如 果 为 室 ， 则 将 计数 器 的 值 增加 1， 并 且 将 SESSION 变量 赋值 为 1。 此 时 ， 在 当前 页 中 
SESSION 变量 的 值 已 经 不 为 空 ， 无 论 如何 刷 新 ， 其 值 都 不 会 改变 ， 计 数 器 的 值 也 不 会 增加 。 
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力 设计 过 程 

(1) 创建 index.php 文件 , 输出 网 页 当前 的 访问 量 。 首先 , 初始 化 一 个 SESSION 变量 。 然后, 判断 SESSION 
变量 的 值 是 否 为 室 ， 如 果 值 为 室 ， 则 打开 指定 的 文本 文件 ， 读 取 其 中 存储 的 数据 ， 并 且 将 文本 文件 中 的 数据 值 
增加 1， 同 时 将 新 的 数据 写 入 到 文本 文件 中 ， 关 闭 文件 。 最 后 ， 将 SESSION 变量 赋值 为 1， 其 关键 代码 如 下 : 


<?php session_startO: 
if($_SESSION[temp}—""){ / 济 断 $S_SESSION[temp] 一 "的 值 是 否 为 室 ， 其 中 的 temp 为 自 定义 的 变量 
这 (Sfp=fopen("countertxt"rD) 一 falsejf 
echo "打开 文件 失败 !" 
jelsef 
Scounter=fgets($fp,1024); // 读 取 文件 中 的 数据 
fclose($fp); /关闭 文本 文件 
Scountertt; 1/ 计数 器 增加 1 
Sfp=fopen("counter.txt","w"): /以 写 的 方式 打开 文本 文件 
fputs($fp,$counter); /将 新 的 统计 数据 增加 1 
fclose($fp); 1/ 关闭 文件 
} 
$_SESSION[temp]=1; // 登 录 以 后 ，$_SESSION[temp] 的 值 不 为 定 ， 给 $_SESSION[temp] 赋 一 个 值 1 
} 
> 


02) 在 index.php 文件 中 ， 创 建 mg 标签 ， 在 src 属性 中 调用 gdl.php 文件 ， 完 成 网 站 访问 量 的 输出 。 
(3) 创建 gdl.php 文件 ， 通 过 文件 系统 函数 读 取 存储 在 counter.txt 中 的 网 站 访问 量 的 数据 ， 并 通过 GD2 函 
数 输 出 网 站 访问 量 的 数据 。 
图 秘笈 心 法 
心 法 领悟 264: SESSION 屏蔽 页 面 刷新 对 计数 器 影响 的 弊端 。 
SESSION 变量 防止 重复 计数 的 缺点 是 只 对 当前 页 面 有 效 ， 当 重新 打开 页 面 时 ， 计 数 器 的 值 仍然 会 增加 。 


ep 


趣味 指数 : 傅 疹 闪闪 
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力 实例 说 明 


SESSION 是 一 种 服务 器 端的 会 话机 制 ， 也 就 是 说 在 用 户 与 网 站 断 开 连接 之 前 ， 分 配给 用 户 的 SESSION ID 
不 会 改变 ， 数 据 可 以 在 不 同 页 面 之 间 相互 传递 。 这 样 的 机 制 不 仅 大 大 减少 程序 员 的 工作 量 ， 还 使 程序 运行 效 
率 得 到 提升 ， 使 代码 结构 更 加 清晰 。 本 实例 通过 SESSION 机 制 实 现在 不 同 页 面 之 间 传 递 数据 ， 其 运行 结果 如 
图 5.16 所 示 。 


欢迎 采 到 阴 日 度 度 和 | 


机 二 各 称 : 海 包 楂 让 
于 到 : 
林寺 性 色 : 古老 的 入 及 风 慰 


二 洗 数 : 3 


elololo 


图 5.16 在 不 同 页 面 之 间 传 递 数据 


第 5 章 会 话 应 用 


力 关键 技术 


在 本 实例 中 ，SESSION 技术 的 应 用 如 下 : 

首先 ， 通 过 session_start0 函 数 初始 化 SESSION 变量 。 然 后 ， 应 用 session set_cookie params( 函 数 设置 
SESSION 的 过 期 时 间 。 接 着 ,应 用 $_SESSION[] 全 局 变量 定义 SESSION 变量 的 值 。 最 后 ,应 用 session_destroy() 
函数 删除 SESSION 变量 。 


session_ set_cookie params() 函 数 ， 设 置 SESSION 的 过 期 时 间 ， 其 语法 如 下 : 
void session_set cookie params( int lifetime [, string path [, string domain [ bool secure]]]) 
session_set_cookie_params 0 函数 参数 的 说 明 如 表 5.2 所 示 。 


表 5.2 session_set_cookie_params () 函 数 的 参数 说 明 


。COOKIE 的 生存 期 


。COOKIE 的 有 效 路 径 
。COOKIE 的 有 效 域 
。 COOKIE 在 安全 的 范围 内 被 发 送 


session_destroy0 函 数 ， 结 束 当前 的 会 话 ， 其 语法 如 下 : 
session_destroy(); 


该 函数 清空 会 话 中 的 所 有 资源 ， 彻 底 销毁 SESSION 。 
| | 设计 过 程 


(1) 创建 index.php 文件 ， 设 计 用 户 登录 页 面 ， 并 将 用 户 登 录 信息 提交 到 index_ok.php 文件 进行 处 理 。 

(2) 创建 index_ok.php 文件 ， 完 成 对 表单 中 提交 数据 的 处 理 。 首 先 ， 应 用 session_set_cookie_params() 
函数 根据 表单 中 提交 值 设 置 SESSION 的 过 期 时 间 ， 并 初始 化 SESSION 变量 。 然 后 ， 在 本 页 中 获取 表单 中 提 
交 的 用 户 登录 信息 ， 判 断 管理 员 的 用 户 名 和 密码 是 否 正确 。 如 果 正 确 , 通过 $_SESSION[] 将 用 户 名 和 密码 存储 
到 指定 的 SESSION 变量 中 ， 同 时 跳 转 到 网 站 主页 ， 如果 不 正确 ， 则 给 出 提示 信息 ， 并 跳 转 到 登录 页 ， 其 关键 


代码 如 下 : 
<?php 
Session_set_cookie_params($_POST['check]): /设置 SESSION 的 过 期 时 间 
session_startO; // 初 始 化 SESSION 变量 
if($ POST[sub){ 
if($_POST['user]!="" && $_POST['pwd"]!=""){ 1/ 判断 用 户 名 和 密码 是 否 为 空 
这 $_POST[user] 一 "mr' && $_ POST[pwd]—"mrsoft"){ /判断 管理 员 用 户 名 和 密码 是 否 正 确 


$_SESSION['user] = $_POST['user]:; 
$_SESSION[pwd'] = $_POST[pwd]: 
$ SESSIONT'check] =$ POST['check1: 
echo "<script>alert( 管 理 员 登 录 成 功 ! "window ,location href='ini.php'</script>"; 
jelsef 
echo "<script>alert( 用 户 名 或 者 密码 不 正确 ! ):window-.location href-'index.php'</script>": 
} 
jelse{ 
echo "<script>alert( 登 录用 户 名 或 者 密码 不 能 为 室 ! ):window ,location href-'index php'</script>"… 
} 
} 
> 


(3) 创建 iniphp 文件 ， 编 写 网 站 的 主页 面 。 在 网 站 主页 面 中 应 用 $_ SESSION[] 获 取 SESSION 变量 中 存储 
的 用 户 名 、 密 码 和 SESSION 的 有 效 时 间 ， 同 时 创建 用 户 退 出 的 超 链 接 ， 链 接 到 logout.php 文件 ， 其 关键 代码 
如 下 : 
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<?php 

session startO: 

echo "当前 时 间 : " date(Y-m-d H:i:s)."<br>"; 
echo "用 户 名 : ".$_SESSION[user]."<br>"; 
echo "密码 : ".$_SESSION[pwd]."<br>"; 
echo "时 效 ，"S_SESSION[check]." 秒 <br>"; 


echo "<a href=1ogoutphp> 退 出 </a>"; 
> 
(4) 创建 logout.php 文件 ， 应 用 session_destroy0 函 数 结束 当前 会 话 ， 即 退出 登录 ， 其 关键 代码 如 下 : 
<?php 
Session 1_startO; 


session_destroyO); 
Ep "<script>alert( 退 出 登录 ! );:window.location href-=index.php':</script>"; 


| | 秘笈 心 法 


心 法 领悟 265: SESSION 的 启动 。 
启动 SESSION 有 两 种 方法 : 第 一 种 是 使 用 session_start0 函 数 ， 第 二 种 是 应 用 session_register0 函 数 为 会 话 
登录 一 个 变量 来 隐 含 地 启动 会 话 。 笔 者 推荐 使 用 第 一 种 方法 ， 因 为 第 二 种 方法 的 运用 需要 设置 php.ini 文件 中 
register_globals 的 值 为 ON， 否则 使 用 session_register0 函 数 启动 会 话 会 弹出 一 个 错误 信息 。 
高 级 
趣味 指数 : bode 


实例 266 


图 实例 说 明 


购物 车 是 在 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ”， 为 我 们 在 网 上 购物 提供 很 大 的 方便 ， 不 用 担 
心 一 次 购买 多 个 商品 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 商品 放 入 购物 车 中 ， 等 选 购 完 后 ， 一 起 进行 结算 。 在 
本 实例 中 ， 我 们 将 介绍 SESSION 购物 车 的 实现 方法 ， 其 运行 结果 如 图 5.17 所 示 。 


到 区 出 (号 


E0D7 区 油 册 O7 汪 7 交 区 卫 3 


商品 列表 
商品 名 称 | 单价 (元 ) 当量 (个 ) 4 计 撞 作 
相机 320 2800 | 更 9 数量 日 了 法 项 
手机 3500 E 7000 | 。 更 对 量 扩 队 这 项 
<< 多 针 购 买 清 宇 购物 车 > 商品 全 额 总 计 : 9800 元 EE 


图 5.17 SESSION 购物 车 


图 关键 技术 


SESSION 购物 车 , 顾名思义 ， 主 要 是 应 用 SESSION 变量 来 实现 的 。 而 所 谓 的 购物 车 就 是 通过 $_SESSION[] 
创建 的 两 个 SESSION 变量 ， 其 中 goodsid 存储 商品 的 ID， goodsnum 存储 商品 的 数量 。 

购物 车 的 操作 流程 如 下 : 首先 ， 登 录 到 网 站 中 浏览 商品 。 然 后 ， 购 买 指定 的 商品 ， 进 入 购物 车 页 面 ， 在 其 
中 可 以 实现 很 多 操作 ， 包 括 更 改 商 品 数量 、 删 除 商品 、 清 空 购物 车 、 继 续 购物 等 。 最 后 ， 填 写 收 货 人 信息 ， 生 
成 订单 ， 执 行 订单 打印 、 预 览 和 提交 等 操作 。 具 体操 作 流 程 如 图 5.18 所 示 。 
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更 改 购物 车 
| 中 商品 数量 | 
删除 购物 车 


中 指定 商品 
EE 


将 商品 添 
加 到 购物 车 


查看 购物 车 内 商品 


ey 
取消 订单 


图 5.18 ”购物 车 操作 流程 


四 设计 过 程 

应 用 SESSION 技术 开发 购物 车 的 步骤 如 下 : 

(1) 创建 index.php 页 面 ， 实 现 商品 展示 功能 。 设 计 原理 是 : 从 数据 库 中 读 取 商 品 信息 ， 将 商品 信息 在 页 
面 中 进行 分 栏 、 分 页 显示 ， 并 且 为 商品 设置 购买 和 查看 购物 车 的 超 链接 ， 运 行 结果 如 图 5.19 所 示 。 


9 ?本 


而 a 


商品 4 个 此 页 ?个 第 1 页 共 2 页 首页 上 -页 ET 
图 5.19 ”购物 车 商品 展示 页 面 
(2) 创建 by_commodity.php 文件 ， 实 现 购买 功能 ， 即 向 购物 车 中 添加 商品 。 首 先 创建 一 个 购物 车 ， 然 后 
判断 购物 车 中 是 否 为 室 ， 如 果 为 室 ， 则 将 商品 展示 页 中 “购买 ” 超 链接 传递 的 商品 ID ($_GET[id]) 和 数量 添 
加 到 购物 车 中 ; 如 果 不 为 室 ， 则 判断 要 添加 的 商品 ID 是 否 在 购物 车 中 已 经 存在 ， 如 果 存 在 则 不 能 重复 添加 ， 否 
则 将 跳 转 到 shopping.php 购物 车 页 面 ， 其 代码 如 下 : 


<?php 

Session _start0; / 审 始 化 SESSION 变量 

header ( "Content-type: text/html: charset=UTF-8" ): // 设 置 文件 编码 格式 

if($_SESSION["goodsid"]—"" && $_SESSION["goodsnum"]—""){ // 判 断 SESSION 变量 是 否 为 宝 

$_SESSION["goodsid"]=$_GET["id"]."@": // 如 果 SESSION 变量 为 室 ， 则 为 其 赋值 为 商品 的 ID， 并 以 @ 分 隔 

$_SESSION["goodsnum"]="1@": // 如 果 SESSION 变量 为 室 ， 则 为 其 赋值 为 1， 并 以 @ 分 隔 

jelsef 1 如果 SESSION 变量 不 为 空 
Sarray=explode("@".$_SESSION["goodsid")): // 以 @ 为 分 隔 符 ， 将 SESSION 变量 中 的 数据 写 入 到 数组 中 

iin_array($_GET["id"].Sarray)){ /判断 数组 中 是 否 存在 指定 的 个 
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echo "<script>alert(' 该 商品 已 经 被 放 入 购物 车 ! ");history.back0;</script>"; 


exit; 


k /如 果 数 组 中 不 存在 指定 的 ID， 则 说 明 该 商品 还 没有 放 入 购物 车 中 
$_SESSION["goodsid"] =$_GET["id"]."@": /将 该 商品 添加 到 购物 车 中 
$_SESSION["goodsnum"].="1@": /更改 商品 数量 
a "<script>window location href='shopping_car.php';</script>"; 
> 
(3) 创建 shopping.php 购物 车 页 面 ， 对 购买 商品 进行 统计 ， 包 括 购买 商品 的 数量 、 每 种 商品 的 金额 和 总 金 
， 并 且 实 现 删除 购物 车 中 商品 、 更 改 购物 车 中 商品 数量 和 清空 购物 车 的 功能 ， 同 时 设置 “继续 购买 ” 超 链接 ， 
二 请 参考 本 书 光盘 。 
(4) 创建 change_commodity_counts.php 文件 ， 实 现 更 改 购物 车 中 商品 数量 的 功能 。 首 先 获取 shopping.php 
页 面 表 单 中 提交 的 商品 数量 和 商品 也 ， 然 后 通过 正则 表达 式 验 证 商品 数量 是 否 为 正 整 数 ， 最 后 根据 商品 ID 找 
到 指定 的 商品 ， 更 改 商 品 数量 ， 并 返回 到 购物 车 页 面 ， 其 代码 如 下 : 


<?php 
session_ start(; 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
Sid=$_POST["id"]; /获取 商品 加 
Snum=$_POST["goodsnum"]; /获取 商品 数量 
Spreg="/^[0-9]*[0-9]$I^[0-9]*[0-9]$/"; /编写 正则 表达 式 
if($num—""){ // 判 断 提 交 的 值 是 否 为 空 
echo "<script>alert( 数 量 不 能 为 空 !):history.backO:</script>": 
exit; 
}else if(!preg_match($preg,$num,$str){ /1/ 判 断 提交 的 数据 是 否 是 正 整数 
echo "<script>alert( 数 量 只 能 为 正 整 数 !");history.backO;</script>"; 
exit; 


} 
Sarrayid=explode("(®",$_SESSION["goodsid"]); 
Sarraynum=explode("@",$_SESSION["goodsnum"]); 


Skey=array_search(Sid,Sarrayid); // 在 数组 中 搜索 给 定 的 值 ， 如 果 成 功 则 返回 相应 的 键 名 
Sarraynum[$key]=Snum:; // 更 改 商品 数量 
$_SESSION["goodsnum"]=implode("@",$arraynum); /更改 商品 数量 


2 "<script>window.location.href='shopping_car.php';</script>"; 


5 创建 delete_commodity.php 文件 ， 实 现 删除 购物 车 中 指定 商品 的 功能 。 首 先 获取 超 链接 中 传递 的 商品 
ID， 然 后 将 SESSION 中 的 字符 串 数据 转换 成 数组 ， 并 根据 商品 ID 获取 指定 要 删除 的 商品 的 键 名 ， 最 后 根据 键 
名 为 指定 的 数组 赋 空 值 ， 并 重新 将 数组 添加 到 购物 车 中 ， 代 码 请 参考 本 书 光盘 。 

(6) 创建 clear_shopping_car.php 文件 , 实现 清空 购物 车 的 功能 。 即将 SESSION 变量 $_SESSION["goodsid"] 
和 $_SESSION["goodsnum"] 赋 空 值 ， 其 代码 如 下 : 


<2php 
session_startO; /初始 化 SESSION 变量 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
$_SESSION["goodsid"]=""; /为 购物 车 的 ID 赋 空 值 
$_SESSION["goodsnum"]=""; // 为 购物 车 数量 赋 空 值 
echo "<script>window.location.href='shopping_car.php':</script>"; // 完 成 清空 操作 ， 跳 转 到 购物 页 面 

> 

秘笈 心 法 


心 法 领悟 266: 初始 化 SESSION 变量 和 删除 SESSION 变量 。 

在 应 用 SESSION 变量 实现 购物 车 功能 时 ， 最 容易 出 现 的 一 个 错误 就 是 忘记 初始 化 SESSION 变量 ， 如 果 在 
文件 中 没有 初始 化 SESSION 变量 ， 那 么 在 页 面 之 间 就 获取 不 到 SESSION 变量 中 存储 的 数据 。 

在 实例 266 中 ， 应 用 session_destroy0 函 数 删除 SESSION， 而 在 本 实例 中 通过 直接 为 SESSION 变量 赋 空 值 


的 方法 清空 SESSION， 还 可 以 通过 unset0 函 数 删除 指定 的 SESSION 变量 。 
‘unset ($_SESSION['user] ) : 
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也 可 以 通过 直接 为 $ SESSION 赋 一 个 空 数 组 的 方式 清空 SESSION。 
$ SESSION = armray0 ; 


趣味 指数 : 斌 请 请 疹 ; 


图 实例 说 明 

SESSION 的 功能 十 分 强大 ， 这 一 点 在 业界 中 是 公认 的 。 但 是 越 是 功能 强大 或 者 技术 含量 高 的 方法 往往 执行 
条 件 也 越 苛刻 ，SESSION 技术 的 应 用 也 是 如 此 。 在 本 实例 中 我 们 将 解决 一 些 在 SESSION 应 用 中 常见 的 问题 
包括 session_startO 函 数 的 应 用 限制 (其 错误 使 用 的 运行 结果 如 图 5.20 所 示 )。 和 使 用 COOKIE 函数 设置 SESSION 
过 期 时 间 时 需要 注意 的 事项 。 


WwW: arning session_start() [function.session-start]: Cannot I 
Send session cache limiter - headers already sent (output 
started at FAppServiwwwiMR\DS\013\index.php2) in 

FAppServwww MR\0s013 ndex.php on line 3 到 


加 于 国志 EC 


图 5.20 session_startO 函 数 使 用 限制 


图 关键 技术 


(1) session_start0 函 数 : 使 用 此 函数 之 前 浏览 器 不 能 有 任何 输出 ， 否 则 会 输出 如 图 5.20 所 示 的 错误 信息 。 
(2) 使 用 COOKIE 函数 为 SESSION 设 定 过 期 时 间 时 ， 首 先 ， 要 确定 浏览 器 支持 COOKIE， 其 次 ， 要 将 
Session_startO 函 数 放 置 在 setcookie0 函 数 之 前 ， 否 则 客户 端 不 会 创建 COOKIE 文件 。 


| 设计 过 程 


(1) 创建 ndex.php 文件 ， 编 写 PHP 脚本 ， 并 应 用 echo 语句 在 session_start0 函 数 之 前 输出 一 个 字符 串 ， 
其 代码 如 下 : 
<?php 
echo “mrsoft"; /输出 一 个 字符 串 
session_startO; /初始 化 SESSION 变量 
> 


当 运 行 本 代码 时 , 将 输出 如 图 5.20 所 示 的 错误 信息 , 将 echo 语句 放置 于 session_start0 函 数 之 后 即 可 解决 该 
问题 。 
(2) 利用 COOKIE 机 制 设置 SESSION 的 过 期 时 间 。 在 index.php 文件 中 ， 首 先 初始 化 SESSION 变量 ， 然 
后 定义 一 个 SESSION 变量 pic， 最 后 通过 setcookie0 函 数 设 置 SESSION 变量 的 过 期 时 间 ， 其 代码 如 下 : 


<?php 
session_ start(); // 启 动 SESSION 
$_SESSION['pic] = "mrsoft"; /设置 SESSION 变量 
setcookie("pi"."$_SESSION[pic]".time0+60): /设置 SESSION 的 过 期 时 间 


> 
运行 本 代码 ， 可 以 在 客户 端的 COOKIE 文件 夹 下 查看 到 创建 的 COOKIE 文件 。 但 是 ， 如 果 将 setcookie0 函 
数 放置 在 session_start0 函 数 之 前 ， 运 行 本 代码 ， 在 客户 端的 COOKIE 文件 夹 中 找 不 到 对 应 的 COOKIE 文件 。 


图 秘笈 心 法 


心 法 领悟 267: 通过 session_set_cookie params0 函 数 延长 SESSION 的 生命 周期 。 
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在 开发 程序 的 过 程 中 可 能 会 遇 到 这 样 的 情况 ， 以 会 员 身 份 登录 一 个 网 站 后 ， 若 停留 的 时 间 较 长 ， 再 在 这 个 
网 站 中 发 布 信息 时 ， 会 提示 “您 没有 登录 ， 请 登录 后 再 发 布 信息 ”， 之 所 以 会 出 现 此 类 问题 ， 是 因为 在 登录 时 
定义 的 SESSION 变量 已 经 过 期 ， 导 致 当前 用 户 不 可 用 ， 需 要 重新 登录 。 解 决 此 问题 最 好 的 方法 就 是 通过 
session_set_cookie_params() 函 数 延 长 SESSION 的 生命 周期 , 即 应 用 session_set_cookie_params0 函 数 将 SESSION 
的 过 期 时 间 设 置 为 0。 读 者 不 妨 自 己 试 一 试 ， 看 是 否 能 够 延长 SESSION 的 生命 周期 。 


力 实例 说 明 


在 Web 网 站 的 开发 过 程 中 ， 需 要 对 不 同 的 登录 用 户 设置 不 同 的 权限 。 如 果 是 管理 员 ， 则 可 以 登录 网 站 后 台 
管理 系统 ， 管 理 网 站 的 数据 ;如果 是 普通 用 户 ， 则 只 有 浏览 网 站 的 权限 ， 不 可 以 进入 网 站 的 后 台 管 理 系统 。 在 
本 实例 中 ， 当 输入 正确 的 用 户 名 mr、 密 码 mrsoft 时 ， 将 输出 如 图 5.21 所 示 的 页 面 。 

如 果 直 接 访问 main.php 页 面 ， 即 以 普通 用 户 的 身份 访问 ， 那 么 将 输出 如 图 5.22 所 示 的 提示 信息 ， 并 跳 转 到 


首页 
a 二 个 营 TA 
Cd CR LR A Co 
op RPMNR 
| ~ ' 
= Cepyrrghl O1999 2010 青 可 和 骨 上 有 有 公司 
图 5.21 管理 员 登 录 成 功 展示 的 页 面 图 5.22 普通 用 户 访问 main.php 的 效果 
图 关键 技术 


本 实例 的 关键 是 在 main.php 文件 中 判断 SESSION 变量 的 值 是 否 是 管理 员 的 用 户 名 和 密码 ， 如 果 是 ， 则 可 
以 访问 本 页 面 ， 否 则 将 给 出 提示 信息 ， 并 跳 转 到 登录 页 面 ， 其 关键 代码 如 下 : 


<?php 
session_startO: /初始 化 SESSION 变量 
if($_SESSION['user]—"mr" || $_SESSION['pass ]—"mrsoft"){ /1/ 判 断 SESSION 变量 的 值 是 否 正确 
> 
…// 省 略 了 部 分 代码 
<?php 
jelsef /如果 值 不 正确 ， 则 跳 转 到 首页 
echo "<script>alert( 您 不 具备 访问 本 页 面 的 权限 !):window-location href='index.php':</script>"; 
} 
> 
图 设计 过 程 


(1) 创建 index.php 文件 ， 编 写 用 户 登录 页 面 ， 将 用 户 登录 信息 提交 到 index_ok.php 文件 中 。 
(2) 创建 index_ok.php 文件 ， 初 始 化 SESSION 变量 ， 通 过 $_POST[] 方 法 获取 表单 提交 的 用 户 名 和 密码 ， 
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完成 对 用 户 名 和 密码 的 验证 。 如 果 正 确 ， 则 将 用 户 名 和 密码 赋 给 SESSION 变量 ， 并 通过 JavaScript 脚本 跳 转 到 
main.php 页 面 ;否则 ， 通 过 JavaScript 脚本 给 出 提示 信息 ， 跳 转 到 index.php 页 面 ， 其 代码 如 下 : 


<?php 

Session_ start():; /初始 化 SESSION 变量 
if($_POST[user]—"mr" && $ POST[pass] 一 "mrsoft){ /判断 提交 的 用 户 名 和 密码 是 否 正确 
$_SESSION[user]-$_ POST[user]: /如果 正确 ， 将 其 赋 给 SESSION 变量 


$ SESSION[passT-S POST['pass: 
echo "<script>alert( 欢 迎 您 的 到 来 ");window.location-href='main php':</script>"; 
Jelse{ 
echo "<script>alert( 您 输入 的 用 户 名 和 密码 不 正确 !);window.location href~'index.php';</script>"; 
} 
> 


(3) 创建 main.php 页 面 ， 初 始 化 SESSION 变量 ， 通 过 $_ SESSION[] 方 法 获取 SESSION 变量 的 值 ， 并 判断 
其 是 否 为 真 ， 如 果 为 真 ， 则 输出 该 页 面 的 内 容 ， 和 否则 ， 通 过 JavaScript 脚本 给 出 提示 信息 ， 跳 转 到 index.php 页 
面 。 其 代码 可 以 参考 本 实例 的 关键 技术 。 


图 秘笈 心 法 

心 法 领悟 268: 通过 SESSION 控制 网 站 后 台 管理 系统 的 权限 。 

本 实例 介绍 的 是 通过 SESSION 控制 用 户 访问 权限 的 方法 。 实 例 中 只 是 对 一 个 简单 的 main.php 页 面 设置 访 
问 权 限 ， 在 实际 的 程序 开发 过 程 中 ， 可 以 将 其 扩展 到 整个 网 站 的 后 台 管理 系统 中 ， 即 对 网 站 后 台 管 理 系 统 中 的 
所 有 文件 增加 权限 的 访问 控制 ， 从 而 确保 后 台 管 理 系 统 不 被 普通 用 户 访问 ， 保 证 网 站 数据 的 安全 。 


本 
趣味 指数 : | 


国 实例 说 明 


将 SESSION 数据 变量 存储 于 服务 器 端 是 一 种 较 安 全 的 做 法 , 但 是 设想 一 下 , 像 校内 网 这 样 的 日 访问 量 过 亿 ， 
拥有 用 户 1500 万 的 大 型 网 站 ， 如 果 将 所 有 用 户 的 SESSION 数据 全 部 存储 在 服务 器 端 ， 将 消耗 巨大 的 服务 器 资 
源 。 所 以 程序 员 在 制作 大 型 网 站 时 将 SESSION 存储 于 服务 器 端 虽然 安全 , 但 却 不 是 很 好 的 选择 。 如 果 将 SESSION 
数据 存储 于 数据 库 中 ， 那 么 就 可 以 减轻 服务 器 的 压力 ， 同 时 数据 也 是 比较 安全 的 。 这 就 是 本 实例 将 要 介绍 的 内 
容 一 一 如 何 将 SESSION 数据 存储 于 数据 库 中 ， 其 运行 结果 如 图 5.23 所 示 。 


- SESSION 
SESSION_ID SESSION_VALUES SION_TIME 
stii3cvokp Tn617909b8s727 bsers2. mr ,pwds6. mrsoft” :12 
stti3cuckSp7o61790qbss727 vers "mrpwds6."mrson”; 


图 5.23 将 SESSION 存储 到 数据 库 


图 关键 技术 


将 SESSION_ID 存储 于 数据 库 中 ， 应 用 的 是 session_set_save_handler0 函 数 。 该 函数 调用 自 定义 函数 ， 完 成 
将 SESSION_ID 存储 于 数据 库 中 的 操作 ， 其 语法 如 下 : 

bool session_set_save_handler ( string open. string close. string read. string write. string destroy. string gc) 

Session set Save_handlerO 函 数 的 参数 说 明 如 表 5.3 所 示 。 


PHP 开发 实战 1200 例 (第 I 卷 ) 


表 5.3 session_set_save_handler(0) 函 数 的 参数 说 明 
参 数 说 了 明 
open(save_path.session name) | 找到 session 存储 地 址 ， 取 出 变量 名 称 
close0 | 不 需要 参数 ， 关 闭 数据 库 
read(key) | 读 取 session 键 值 ，key 对 应 session id 


其 中 data 对 应 设置 的 session 变量 
destroy(key) 注销 session 对 应 的 session 键 值 


gc(expiry time) 清除 过 期 的 session 记录 
这 是 一 个 非常 特殊 的 函数 ， 因 为 一 般 函 数 的 参数 都 是 变量 ， 但 是 此 函数 的 参数 为 6 个 函数 。 


上 说 明 : 在 本 实例 中 ， 编 写 了 6 个 自 定义 函数 作为 session_ set_save_handleO 函 数 的 参数 ， 自 定义 函数 的 语法 
请 参考 设计 过 程 。 


图 设计 过 程 

(1) 创建 index.php 文件 ， 编 写 用 户 登录 页 面 ， 将 数据 提交 到 index_ok.php 文件 中 。 

(2) 创建 index_ok.php 文件 ， 编 写 6 个 自 定义 函数 作为 session_set_save_handle0 函 数 的 参数 ， 同 时 
session_set_save_handle0 函 数 将 表单 中 提交 的 用 户 名 和 密码 赋 给 SESSION 变量 ,登录 成 功 后 跳 转 到 main.php 页 
面 ， 其 关键 代码 如 下 : 

<?php 


function _openO{ 
global $conn; 


$conn = mysql_connect ( "localhost", "root", "111" ) or die ( "连接 mysql 出 现 错误 " ); 
mysql_select_db ("db_database05", Sconn ) or die ("连接 数据 库 出 现 错误 " ); 


write(key.data) 


mysql_query ( "SET NAMES utf8" ); // 设 置 数据 库 编 码 
Teturn(true); 

} 

function _closeO{ /关闭 数据 库 
global $conn: 
mysql_close($conn); 
return(true); 

} 

function read(Skey){ 
global $conn; // 全 局 变量 Sconn 连接 数据 库 
Stime = timeO; // 设 定 当前 时 间 
$sql = "select session_data from tb_session Where session key = '$key' and session time > $time"; 
$result = mysql query($sql.$conn):; 
Srow = mysql_fetch_array($result): 
if (Srow)}{ 

Teturn(Srow['session_data"]): /上 返回 SESSION 名 称 及 内 容 

Jelse{ 
i Teturn(false): 

} 

function_write(Skey,$data){ /首先 判断 SESSION 是 否 失效 ， 如 果 失 效 则 重新 向 数据 库 中 添加 数据 
global $conmn; 
Stime 一 60+60: /设置 失效 时 间 
S$overdue time = time0 + Stime: // 得 到 UNIX 时间 截 


$sql = "select session_data from tb_session where session key = $key and session time > Soverdue time": 
Sresult = mysql_query($sql.Sconn): 


证 (mysql_ num rows(Sresult) — 0 ){ /没有 结果 
$sql = "insert into tb_session values('$key'.'Sdata', Soverdue_time)"; /搬入 数据 库 sql 语句 
Sresult = mysql._query($sql.Sconn); 
Jelse{ /否则 ,更 新 SESSION 的 数据 
Ssql = "update tb_session set session key = 'Skey'session_data 一 '$data'session time = Soverdue time where session key = '$key"; 
/定义 更 新 语句 
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Sresult = mysql_ query($sqLSconn): /| 执行 更 新 语句 
et /上 返回 标识 
am RE 


session where session key 一 'Skey": /1/ 删 除数 据 库 sql 语句 
Sresult= redo 


Soverdue_time = time(); // 将 参数 $expiry_time 赋值 为 当前 时 间 截 
$sql = "delete from tb ee time < Soverdue time"; // 删 除数 据 库 sql 语句 


session_set_save_handler(" open',' close',' read', write', destroy’, overdue"); 
session start(); 
这 $_POST[sub] 一 "sub"){ 
这 $ POSTTuser1 一 "1$ POSTIpwd1—""){ 
echo "<script>alert( 用 户 名 或 者 密码 不 能 为 空 ! 9; window .location hreE-index php':</script>": 


$ SESSIONP'user] =$ POSTPuser]: 
S$_SESSION[pwd] =$_POST[pwd]; 
echo "<script>alert( 登 录 成 功 ! ); window.location href-main php';</script>"; 


jelsef 


} 
} 


> 
(3) 创建 main.php 文件 ， 连 接 数据 库 ， 通 过 while0 语 句 循环 输出 数据 库 中 存储 的 SESSION 数据 。 
(4) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 连 接 MySQL 数据 库 服务 器 和 db_database05 数据 库 。 


力 秘笈 心 法 


心 法 领悟 269: 注意 SESSION 函数 运用 时 的 放置 顺序 。 

在 运行 SESSION 函数 时 要 特别 注意 它们 的 使 用 顺序 , 尤其 是 session_start0 函 数 , 在 运用 这 个 函数 之 前 浏览 
器 不 能 有 任何 输出 。 还 有 session_save_pathO 和 session_set_cookie_params0 函 数 ， 都 必须 在 session_start0 函 数 之 
前 使 用 ,否则 就 没有 任何 意义 解决 这 个 问题 最 好 的 方法 就 是 通过 session_set_cookie_params0 函 数 延长 SESSION 
的 生命 周期 。 


图 实例 说 明 
SESSION 可 以 实现 数据 在 页 面 之 间 的 传递 ， 并 且 在 SESSION 的 生命 周期 中 一 直 有 效 。 在 本 实例 中 ， 将 运 


用 SESSION 的 这 个 特性 ， 编 写 一 个 简单 的 聊天 室 换 肤 功能 。 在 聊天 室 中 ,根据 提交 的 颜色 值 更 换 聊 天 室 的 背景 
颜色 ， 其 运行 结果 如 图 5.24 所 示 。 


避 |。 在 这 且 吕 了 名 天 各 内 奉 。 半生 大 页 进 守 和 天 宇 了 珊 风 


了 要 天 室 中 传 有 不 寻 记 的 和 地 法 的 内 容 ， 放 知人: 再 二 村 外 


过 全 百 次 的 可 名， 处- 而 也 本 大 妈 更 于 


图 5.24 更 换 聊 天 室 背景 颜色 
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图 关键 技术 


本 实例 中 , 首先 获取 超 链接 中 传递 的 参数 值 。 然后 , 将 参数 值 赋 给 指定 的 SESSION 变量 。 最后, 将 SESSION 
变量 设置 为 页 面 背 景 颜 色 bgcolor 的 值 ， 进 而 实现 聊天 室 背 景 颜 色 的 更 换 ， 其 关键 代码 如 下 : 
pn // 将 超 链接 传递 的 参数 值 赋 给 SESSION 变量 
> 
<body bgcolor="<?php if($_SESSION['bgcolor]—""){echo "white";}else{echo $_SESSION[bgcolor]:}?>"> 
在 body 标记 中 ， 通 过 站 语句 判断 SESSION 变量 的 值 ， 如 果 值 为 室 ， 则 设置 bgcolor 的 值 为 white; 否则 ， 
直接 将 SESSION 变量 作为 bgcolor 的 值 。 
图 设计 过 程 
(1) 创建 ndex.php 文件 ， 设 计 一 个 简单 的 聊天 室 页 面 ， 在 聊天 室 的 log 中 插入 一 个 颜色 选项 卡 图 片 ， 并 
为 每 种 颜色 设置 矩形 热点 链接 ， 链 接 到 index.php 文件 ， 同 时 定义 超 链接 参数 col， 参 数值 是 热点 链接 对 应 的 颜 
色 值 。 
(2) 在 index.php 文件 中 ， 获 取 超 链接 传递 的 参数 值 ， 并 将 其 赋 给 SESSION 变量 ， 然 后 根据 SESSION 变 
量 的 值 设置 页 面 中 body 标记 的 bgcolor 的 值 ， 完 成 聊天 室 背 景 颜色 的 更 换 。index.php 的 关键 代码 如 下 : 
a // 获 取 超 链接 传递 的 参数 值 ， 并 赋 给 SESSION 变量 
> 


<body bgcolor="<?php if($ SESSION['bgcolor|=—""){echo “white";}else{echo $ SESSIONTbgcolor1:}?>"> 
/省略 了 部 分 代码 

<map name="Map" id="Map"> 

<area shape="rect" coords="4,3,27,26" href="index.php?col=0066FF" /> 
<area shape="rect" coords="64,5,87,26" href="index.php?col=00CCFF" /> 
<area shape="rect" coords="31,34,55,56" href="index.php?col=999900" /> 
<area shape="rect" coords="218,64,237,85" href="index.php?col=CC9933" /> 
<area shape="rect" coords="184,33,209,55" href="index.php?col=CC6600" /> 
<area shape="rect" coords="214,7,237,28" href="index.php?col=3399FF" /> 
<area shape="rect" coords="8,63.27,87" href="index.php?col=996633" /> 
<area shape="rect" coords="65.61.88.87" href="index.php?col=99CC33" /> 
<area shape="rect" coords="152,61,177,87" href="index.php?col=CC3333" /> 
</map> 

</body> 


秘笈 心 法 

心 法 领悟 270: 编程 思想 比 编程 技术 更 重要 。 

在 本 实例 中 只 是 将 聊天 室 作 为 实例 开发 的 一 个 大 背景 ， 并 没有 实现 聊天 室 的 功能 ， 其 目的 是 展示 如 何 通过 
SESSION 设置 聊天 室 的 背景 颜色 。 本 方法 虽然 很 简单 ， 但 是 体现 的 是 页 面 换 肤 的 基本 原理 ， 在 具体 的 实战 开发 
中 ， 读 者 可 以 将 这 个 技术 进行 升华 ， 不 但 可 以 改变 背景 的 颜色 ， 而 且 可 以 对 图 片 进行 更 换 。 程 序 设计 的 原理 非 
常 简单 ， 难 的 是 如 何在 原理 的 基础 上 让 内 容 更 加 丰富 ， 这 就 要 求 程序 开发 者 有 自己 独到 的 开发 思想 。 


提高 网 站 访问 的 效率 高 级 
起 味 指数 : 侠 侠 容 容 


图 实例 说 明 


SESSION 缓存 将 网 页 中 的 内 容 临 时 存储 到 客户 端正 的 Temporary Internet Files 文件 夹 下 。 当 网 页 被 第 一 次 
浏览 后 ， 页 面 的 部 分 内 容 在 规定 的 时 间 内 就 被 临时 存储 在 客户 端的 临时 文件 夹 中 ， 这 样 下 次 访问 此 页 面 时 ， 就 
可 以 直接 读 取 缓存 中 的 内 容 ， 从 而 提高 网 站 的 浏览 效率 。 但 是 如 果 不 对 SESSION 缓存 做 定期 处 理 ， 也 会 给 服务 
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器 带 来 压力 。 本 实例 将 讲解 SESSION 缓存 的 运用 和 清理 方法 ， 其 运行 结果 如 图 5.25 所 示 。 


请 理 SESSION 缓 存 


sema»: DriVate 
» sa: 3Oom 


清理 溉 村 


5.25 输出 缓存 信息 


图 关键 技术 


在 本 实例 中 应 用 session_cache limiter0 函 数 创建 缓存 ， 应 用 session_save_pathO 函 数 设置 缓存 文件 的 存储 路 
径 ， 应 用 session_cache_expiry0 函 数 设置 缓存 时 间 。 


Session_cache limiterO 函 数 ， 用 于 创建 SESSION 缓存 ， 其 语法 如 下 : 
String session_cache limiter ( [string cache limiter]) 
参数 cache limiter 用 于 设置 缓存 的 方式 ， 参 数值 说 明 如 表 5.4 所 示 。 


表 5.4 cache_limiter 参数 值 的 说 明 


参 数 值 说 了 明 
nochache 不 设置 缓存 
private 私有 方式 
private nochache 私有 方式 ， 但 不 过 期 
public 公有 方式 


session_cache_expire 0 函数 ， 用 于 设置 缓存 时 间 ， 其 语法 如 下 : 

int session_cache_expire ( [int new_cache_expire]) 

参数 cache_expire 为 可 选 参数 ， 设 置 SESSION 的 过 期 时 间 ， 单 位 为 分 钟 。 默 认 过 期 时 间 是 180 分 钟 ( 即 不 
设置 参数 值 的 情况 下 ) 。 

session_save_path0) 函 数 ， 取 得 或 者 重新 配置 目前 SESSION 的 存储 路 径 ， 其 语法 如 下 : 

string session_save_path([string path]) 

如 果 设 置 参数 path, 表示 重新 设置 SESSION 的 存储 路 径 ; 如果 不 设 置 参 数 path, 表示 直接 获取 当前 SESSION 
的 存储 路 径 。 


设计 过 程 
(1) 创建 index.php 文件 。 首 先 ， 定 义 SESSION 临时 缓存 文件 夹 路 径 并 开启 缓存 ， 设 置 缓存 时 间 为 30 分 
钟 ， 启 用 SESSION， 并 设置 SESSION 变量 ， 其 代码 如 下 : 


<?php 

Spath= /tmp/; /定义 缓存 文件 的 临时 存储 路 径 
session_save_path($path): /设置 缓存 存储 路 径 
session_cache limiter('private’); /设置 缓存 方式 

$session_cache = session_cache limiterO: /开启 缓存 
Session_cache_expire(30): /定义 缓存 时 间 

S$session expire = session_cache expire(): // 设 置 缓存 时 间 

session startO: /初始 化 SESSION 变量 
S$_SESSION['cache] = $session_cache: /为 SESSION 变量 赋值 


$ SESSION['expire] = $session expire: 
> 


359 


PHP 开发 实战 1200 例 (第 I 卷 ) 


(2) 在 index.php 文件 中 ， 获 取 并 输出 缓存 中 存储 的 数据 ， 创 建 超 链 接 ， 执 行 清理 缓存 的 操作 ， 清 理 方法 
是 为 $ SESSION 赋 一 个 空 数 组 值 ， 并 应 用 session_destroy0 函 数 彻底 删除 会 话 ， 其 关键 代码 如 下 : 
让 href = 'index.php?cache=0> 清 理 缓存 </a>": 
if($_GET[cache] 一 "0"){ 


$_SESSION = amay0; /清空 SESSION 
Session /销毁 会 话 


destroyO; 
echo "<script>alert( 清 理 SESSION 缓存 成 功 ):location href='http://www.mrbccd.com'</script>"; 
> 


> 


图 秘 签 心 法 
心 法 领悟 271: 运用 SESSION 缓存 的 注意 事项 。 

(1) SESSION 缓存 被 存储 于 客户 端 。 如 果 用 户 未 设 定 SESSION 缓存 的 临时 目录 ， 默 认 情况 下 存储 于 客户 
端 正 的 Temporary Internet Files 文件 夹 下 。 以 XP 系统 为 例 ，Temporary Internet Files 文件 夹 所 在 路 径 为 
C:\Documents and Settings\Administrator\Local Settings\Temporary Internet Files。 

(2) 虽然 可 以 通过 缓存 时 间 函 数 设 置 缓存 过 期 时 间 ， 但 是 在 过 期 之 后 并 不 能 够 删除 存储 在 客户 端 缓存 文件 
夹 中 的 缓存 文件 ， 缓 存 文 件 的 删除 由 Windows 操作 系统 自行 控制 ， 或 者 由 用 户 手 动 删除 。 

(3) session save_pathO、session_ cache limiter()、session_cache_expiry0 函 数 都 必须 在 session_start0 函 数 之 
前 调用 ， 否 则 会 出 现 错误 。 


图 像 与 统计 

控制 、 显 示 图 片 特性 
Jpgraph 类 库 

GD2 国 数 库 


贡 


图 形 图 像 处 理 
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6.1 图 像 与 统计 


像 与 数字 相 结合 ， 既 可 以 美化 页 面 ， 同 时 又 达到 了 突出 显示 的 效果 ， 可 谓 一 举 两 得 。 在 本 节 中 将 向 读者 
展示 图 像 与 统计 结合 的 妙用 ， 和 希望 对 读者 的 开发 和 学 习 有 所 帮助 。 


页 


sh 


SS 


图 实例 说 明 


网 站 计数 器 的 形式 有 很 多 ， 图 形 计数 器 是 比较 常用 的 一 种 。PHP 制作 图 形 计数 器 的 方法 主要 有 两 种 ， 一 种 
是 利用 GD2 函数 直接 绘制 图 形 ， 另 一 种 是 事先 将 图 形 用 图 形 绘制 工具 绘制 出 来 ， 然 后 用 PHP 代码 进行 调用 。 
本 例 将 采用 第 二 种 方式 实现 ， 统 计 网 页 的 访问 量 ， 其 运行 结果 如 图 6.1 所 示 。 
编程 词典 在 线 向 设 为 首页 国 收藏 本 站 入 联系 我 们 
‘| Dam Je sen 

全 业 萌 神 :二 学 、 创 闲 、 甩 宏 吕 行 

公司 再 多 : 以 训 新 技术 为 全 失 ,大 喇 性 地 开发 具有 巨 大 古 二 浊 力 的 而 价值 的 天 品 。 

公司 运 景 : 甩 为 天 有 箭 心 技术 和 本 必 产品 而 科技 公 司 ， 在 革 下 名 所 具有 领 无 的 再 场地 位 ， 

核 帮 价 信 观 : 永 共 人 M 当 依 ， 每 一 天 和 和 在 进步 、 窜 到 夫 骸 ， 刘 局 时 、 充 分 信任 、 平 等 交 直 。 


et 局 -84978981 864578362 
图 6.1 图 形 计 数 器 
图 关键 技术 
图 形 计数 器 的 设计 原理 : 


(1) 为 了 避免 用 户 通 过 刷新 页 面 来 提高 网 站 的 访问 量 ， 通 过 SESSION 变量 防止 重复 计数 。 首 先 ， 通 过 判 
断 $_SESSION [temp] 的 值 是 否 为 空 决定 计数 器 的 值 是 否 加 1， 如 果 该 值 不 为 空 ， 说 明 用 户 正在 访问 该 网 站 ， 这 
时 计数 器 的 值 不 加 1， 反 之 加 1。 

(2) 将 文本 文件 中 存储 的 访问 量 数据 以 数字 图 片 的 形式 输出 。 首 先 ， 应 用 strlenO 函 数 获取 文本 文件 中 数据 
的 长 度 。 然后， 定义 网 站 访问 量 的 最 大 值 为 6 位 数字 (当然 位 数 可 以 根据 实际 情况 设 定 ) ， 用 0 填充 剩余 位 数 。 
最 后 ， 通 过 for 循环 和 switch 语句 ， 将 从 文本 文件 中 读 取 的 数据 以 图 形 的 形式 输出 ， 其 关键 代码 如 下 : 


Slen = strlen ( $counter ): // 获 取 字 符 串 的 长 度 
S$str = str_repeat ( "0", 6 - $len ); /获取 6-$len 个 数字 0 
for($i= 0: $i< strlen ( $str ); $i ++) { /| 获取 变量 $str 的 字符 串 长 度 
Sresult = $str [$i]; 
Sresult = '<img src=images/0.gif>"; 
echo Sresult /循环 输出 Sresult 的 结果 
} 
for($i = 0; $i< strlen ( $counter ); $i++) { /获取 字符 串 的 长 度 
Sresult = $counter [$i]: 
switch ($result) { 
// 如 果 值 为 "0". 则 输出 0.s 让 图 片 
case "0": 
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RE 
Sret [$1] ="1.gif"; 
break 
62 
Sret [$i] = "2.gif"; 


break 
.省略 部 分 代码 
人 /输出 文本 文件 中 存储 的 数据 
} 
图 设计 过 程 
(1) 创建 index.php 页 ， 设 计 网 站 的 页 面 ， 输 出 公司 简介 的 内 容 。 
(2) 在 index.php 页 中 ， 通 过 文件 系统 函数 编写 一 个 文本 计数 器 ， 将 数据 存储 于 文本 文件 counter.txt 中 ， 
并 通过 SESSION 变量 屏蔽 页 面 刷 新 对 计数 器 的 影响 ， 其 关键 代码 如 下 : 


由 EE 


<?php 
session_start (); 
if($_SESSION [temp] —"") { / 淹 断 S_SESSION[temp] 一 "的 值 是 否 为 室 ， 其 中 temp 为 自 定义 的 变量 
if (($fp = fopen ( "counter,txt", "r" )) — false) { 
echo "打开 文件 失败 !"; 
} else { 
$counter = feets ( $fp, 1024 ); // 读 取 文件 中 数据 
fclose ( $f ): /关闭 文本 文件 
Scounter ++; /计数 器 增加 1 
$fp = fopen ( "counter.txt", "w" ); /以 写 的 方式 打开 文本 文件 
fputs ( $fp, Scounter ); // 将 新 的 统计 数据 增加 1 
fclose ( $f ); /关闭 文件 
} 
$_SESSION [temp] = 1: // 为 $_SESSION[temp] 赋 一 个 值 
} 
> 


(3) 在 index.php 页 中 ， 通 过 文件 系统 函数 读 取 文本 文件 中 存储 的 网 站 访问 量 的 数据 ， 并 将 数据 以 图 形 的 
形式 输出 。 代 码 请 参考 关键 技术 中 的 内 容 。 
图 秘笈 心 法 

心 法 领悟 272: 另 一 种 将 数字 转换 成 图 形 的 方法 。 

首先 ， 应 用 函数 intval0 将 计数 器 的 值 转变 成 字符 串 。 设 置 计数 器 最 多 显示 8 位 数字 (当然 位 数 可 以 根据 实 
际 情况 设 定 ) ， 所 以 根据 stlen0 函 数 确定 当前 计数 值 的 位 数 ， 之 后 用 8 减 去 该 位 数值 得 出 剩余 的 位 数 ， 为 了 使 
页 面 美观 ， 剩 余 的 位 数值 用 0 填充 ， 本 的 昌林 六 作 直 人 让 的 数据 ， 其 关键 代码 如 下 : 


Simagenum=intval($num):; 

for($i=0:$i<8-strlen($imagenum):$i++){ 
echo "<img src=images/count/0.gif>"; /用 0 填充 剩余 的 位 数 

} 

for($i=0;Si<strlen(Simagenum):Sit+){ // 通 过 循环 调用 图 片 显示 结果 
echo "<img src=images/count/".substr($imagenum.$i.1).".gif>"; 

} 


A | 
| 
图 实例 说 明 


本 实例 向 读者 介绍 另 一 种 计数 器 ， 即 将 统计 数据 以 GD2 函数 生成 的 图 像 进行 输出 ， 本 实例 的 运行 结果 如 
图 6.2 所 示 。 
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明日 科技 向 设 为 首页 鸭 收 庆 本 站 起 详 系 匠 们 


图 6.2 GD2 图 形 计数 器 


图 关键 技术 
本 实例 联合 应 用 文件 系统 函数 和 GD2 函数 ， 完 成 网 站 访问 量 的 存储 、 读 取 和 输出 ， 其 原理 如 图 6. 3 所 示 。 


直接 输出 
网 站 访问 量 


判断 SESSION 
是 否 为 空 


重新 输出 
网 站 访问 量 


以 写 入 方式 打开 文件 
图 6.3 GD2 图 形 计数 器 设计 原理 

在 这 个 通过 文本 文件 统计 网 站 访问 量 的 程序 中 ， 概 括 起 来 应 用 了 三 方面 的 技术 : 

第 一 方面 ， 文 件 系 统 操作 函数 ， 实 现 数据 的 写 入 、 读 取 功 能 。 

第 二 方面 ，SESSION， 通 过 SESSION 变量 防止 重复 计数 。 

第 三 方面 ，GD2 函数 ， 将 访问 量 数据 生成 图 像 ， 改 变数 据 的 输出 方式 。 
图 设计 过 程 

(1) 创 建 ndex.php 文件 , 完成 页 面 的 设计 , 并 通过 文件 系统 函数 将 网 站 的 访问 量 添加 到 文本 文件 counter.txt 
中 ， 并 且 通 过 SESSION 变量 屏蔽 刷新 功能 对 计数 器 的 影响 。 创建 mg 标签 ， 链 接 到 gd2.php 文件 ， 在 该 文件 中 
将 网 站 访问 量 的 数据 生成 图 像 。 

(2) 创建 gd2.php 文件 ， 应 用 GD2 函数 将 从 文本 文件 中 读 取 到 的 数据 生成 图 像 。 其 中 ， 关 键 是 运用 
imagettftextO0 和 imagestring0 函 数 ， 完 成 对 中 文字 符 串 和 英文 字符 串 的 输出 ， 其 关键 代码 如 下 : 


<?php 
/以 图 形 的 形式 输出 数据 库 中 的 记录 数 
header("Content-type: text/html; charset=UTF-8"); /设置 文件 编码 格式 


打开 文本 文件 
读 取 文件 中 数据 


Scounter=fpets($fh,1024); 

全 lose($ 印 ): 

Sim=imagecreate(240,24); /通过 GD2 函数 创建 画布 
$eray=imagecolorallocate($im.255.255.255): 

$color =imagecolorallocate($im.rand(0.255).rand(0.255).rand(0,255)): // 定 义 字体 颜色 
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$text=" 网 站 的 访问 量 :"; /定义 中 文字 符 串 
Sfont = "Fonts/FZHCJW.TTEF"; 

imagettftext($im,14.0,20,18.Scolor. Sfont. Stext): /| 输出 中 文 
imagestring($im,5,160,5,$counter, $colon): /输出 网 站 的 访问 次 数 


} 
> 


图 秘笈 心 法 

心 法 领悟 273: 通过 imagettftext0 输 出 中 文字 符 串 。 

在 通过 imagettftextO 函 数 输 出 中 文字 符 串 时 ， 如 果 页 面 使 用 的 是 utf-8 编码 ， 那 么 可 以 直接 使 用 这 个 函数 ; 
如 果 页 面 中 使 用 的 是 gb2312 或 者 其 他 编码 ， 那 么 就 必须 应 用 iconv0 函 数 对 要 输出 的 中 文字 符 串 的 编码 进行 转 
换 ， 因 为 imagettftext0 函 数 只 支持 utf-8 编码 。 


实例 274 


趣味 指数 : 食 食 食 页 页 


图 实例 说 明 


在 线 调查 中 的 投票 系统 相信 大 家 都 了 解 ， 在 本 实例 中 ， 将 编写 一 个 简易 的 投票 系统 ， 并 将 投票 结果 以 图 像 
的 形式 进行 输出 ， 运 行 效果 如 图 6.4 所 示 。 


我 最 喜爱 的 运动 员 选项 投票 结果 
rc 欧阳 一 = 
到 商 言 一 二 20 

确认 提交 


图 6.4 输出 投票 结果 


图 关键 技术 

投票 系统 包括 动态 生成 投票 主题 、 动 态 添加 投票 选项 内 容 、 投 票 主题 管理 和 投票 功能 实现 。 这 里 重点 介绍 
在 投票 功能 中 如 何以 图 像 的 形式 输出 投票 结果 。 

在 look_ vote.php 文件 中 , 根据 总 的 投票 数 , 计算 出 每 一 项 所 占 的 比例 , 然后 根据 这 个 比例 计算 输出 的 图 像 ， 


其 关键 代码 如 下 : 
<?php 
$sql="select + from tb_vote where tb_vote_ id-'S_GET[id]": // 显 示 指定 投票 项 
Sresult=mysql_query($sql,$conn); /执行 查询 指定 的 投票 选项 
Srow=mysql fetch_array($result); 1/ 获取 查询 结果 
$s=$row[tb_vote_num]: /计算 总 的 投票 数量 
echo "$row[tb_vote_name]\n"; /输出 投票 选项 的 名 称 
人 
<?php 
这 Srows[tb_ record num] 一 0) // 浏 断 如 果 投 票数 为 0 
Swidth=0; /定义 变量 值 为 0 
else 
Swidth=$rows[tb_record_num]/$s:; /否则 ， 根 据 投票 数 和 总 的 投票 数 计算 输出 所 占 比 例 
if($width!=0){ /以 图 像 的 形式 输出 投票 所 占 比例 

echo "<img sre=". $rows[tb_record_color].".bmp width=".($width*20)." height=10>\n"; 

} 
echo $rows[tb_record_num]."/".$Srow[tb_vote_num]: // 以 数字 输出 投票 数 和 总 的 投票 量 
> 
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力 设计 过 程 


[a] 


look : 


本 实例 的 文件 架构 如 图 6.5 所 示 。 


口 comn 一 一 一 一 一 一 一 一 连接 涩 如 库 文件 夫 
电 -= 一 一 一 一 一 一 一 css 样式 文 件 突 
i 
Lbep 
而 > -> 
Sm 
| 
下 = = 


te if 一 一 一 一 一 一 抽 除 投票 主题 


管理 员 

提交 投票 和 浏览 投票 结果 
处 理 提交 的 投标 

天 加 投票 选项 


图 6.5 投票 系统 的 文件 架构 


说 明 : 本 实例 编写 一 个 简易 的 投票 系统 ， 具 体内 容 请 参考 本 书 光 盘 ， 这 里 只 对 其 中 投票 结果 的 图 像 输 出 进 


行 讲解 。 


这 里 重点 介绍 look votephp 文件 ， 在 该 文件 中 完成 投票 的 提交 操作 和 投 
传递 的 ID， 查 询 出 指定 的 投票 主题 ， 并 计算 出 


Vote_ok.php 页 进行 处 理 。 最 后 ， 执 行 查询 语句 ， 从 数据 库 中 查询 出 投 


关键 代码 如 下 : 
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<?php 

include_once ("conn/conn.php"); 
if(!$ GET [idD) { 

echo "没有 指定 ID! "; 

exit |; 

}else{ 


?> 
/执行 查询 ， 输 出 投票 主题 


<?php 

$sql = "select + from tb_vote where tb_vote id-'$_GET[id]"; /显示 指定 投票 项 
Sresult = mysql query ( $sql. Sconn ); 

Srow = mysql_fetch_array ( $result ); 

$s = $row [tb_vote_num]; 

echo "$rowltb vote namel\n"; 


?> 
/创建 表单 ， 提 交 投 票选 项 
<form action=look_vote_ok php method=post> 
<input type=hidden name=id value="<?php echo $row [tb vote idl: ?>"> 
<input type=hidden name=V_type value="<?php echo $row [tb_vote_ type]: 2> "> 
</form> 
/输出 投票 结果 
<?php 
$sql2 = "select * from tb_vote_record where tb_vote id='$_GET[id]": 
Sresult2 = mysql_query ( $sql2. $conn ); 
while ( $rows = mysql fetch array ( $result2 ) ) { 

?> 
<t> 

<td heipht="25" align="center"> 

<?php 


还 (Srow [tb vote typel—0) { 
echo "<input type=radio name=r value=" . $rows [tb_record id] . ">\n"; 
jelse { 
echo "<input type=checkbox name=r[] value=" . $rows [tb record id] . ">\n"; 
| 
><td> 
<td>&nbsp:<?php 。 echo $rows [tb record namel: ?></td> 
<td>&nbsp: 


果 的 输出 。 首 先 ， 根 据 超 链接 
票 总 数 。 然 后 ， 创 建 表单 ， 提 交 投票 选项 ， 将 数据 提交 到 
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if ($rows [tb_record_num] — 0) 

Swidth =0; 
else 

Swidth = $rows [tb_record_num] / $s; 
if($width !=0) { 

echo "<img sre=" . $rows [tb record color] . "bmp width=" . (Swidth * 20) . " height=10>\n"; 
, 
echo $rows [tb_record_num] . "/". $row [tb_vote_num]; 


P<td> 
</> 


?> 
2 


> 


图 秘笈 心 法 


心 法 领悟 274: 如 何 屏蔽 同一 个 用 户 的 重复 投票 。 

在 本 实例 的 简易 投票 系统 中 , 应 用 SESSION 变量 来 屏蔽 同一 用 户 的 重复 投票 ， 它 可 以 防止 用 户 在 一 次 访 
问 中 进行 重复 投票 。 不 过 本 系统 也 存在 一 个 问题 ， 即 如 果 同 一 用 户 想 再 次 投票 ， 只 要 关闭 当前 页 面 ， 重 新 登录 
即 可 。 


趣味 指数 : 人 穴 侠 评价 | 


上 说 明 


在 本 实例 中 将 介绍 图 像 的 另 一 项 妙用 ， 即 显示 注册 填写 密码 的 安全 强度 。 运 行 本 实例 ， 当 在 密码 文本 框 中 
输入 一 个 密码 时 ， 光 标 离开 后 ， 将 自动 判断 这 个 密码 的 安全 强度 ， 并 以 图 像 的 形式 返回 一 个 判断 结果 ， 其 运行 
结果 如 图 6.6 所 示 。 


© nttp:/www.mrbced com 


jf 训 风 从 半 + 
© Ms 和 


首 页 “明日 图书 。 编程 词典 ”明日 在 线 支 付 


口 用 户 注册 | 


Em: Ginua1103Bsma com * 读 


[304072263 


后 三 码 的 入 式 不 正确 ? 


变 全 ) 
图 6.6 通过 图 像 显示 密码 安全 强度 


图 关键 技术 
对 密码 安全 强度 进行 判断 是 在 JavaScript 脚本 中 ， 应 用 正则 表达 式 来 完成 的 ， 其 原理 如 下 : 
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(1) 对 密码 中 的 值 进行 判断 ， 如 果 只 包含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任意 一 种 ， 那 么 说 明 密码 
安全 强度 差 。 

(2) 对 密码 中 的 值 进 行 判断 ， 如 果 包 含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任意 两 种 ， 那 么 说 明 密 码 安 
全 强度 中 。 

(3) 对 密码 中 的 值 进行 判断 ， 如 果 同 时 包含 数字 、 英 文字 符 串 和 特殊 字符 串 ， 那 么 说 明 密 码 安 全 强 
度 强 。 

在 JavaScript 脚本 中 ， 通 过 search0 方 法 调用 正则 表达 式 ， 完 成 对 密码 值 的 判断 ， 其 关键 代码 如 下 : 

var pl = (form.pwd.value.search(/[a-zA-2]/)!=- DT // 判 断 密码 中 是 否 包 含 英文 字符 串 


var p2 = (form.pwd.value.search(/[0-9]/)!=-1)? // 判 断 密码 中 是 否 包含 数字 
var p3 = (form.pwd.value.search(/[^a-zA-Z0-9 ) DDal: 0; /1/ 判 断 密码 中 是 否 包含 特殊 字符 

varp =p1+p2+p3; /定义 判断 的 返回 值 
if(p—D{ 

chknew_pwd.innerHTMI="<img src='images/1_03.jpg>"; /输出 密码 安全 强度 差 的 图 像 
jelse 这 p 一 2){ 

chknew_pwd.innerHTMI="<img src='images/2_03.jpg>"; /输出 密码 安全 强度 中 的 图 像 
jelse if(p—3){ 

chknew_pwd.innerHTMIL 一 "<img src='images/3_03.jpg>"; /输出 密码 安全 强度 强 的 图 像 
} 

| | 设计 过 程 


本 实例 完成 一 个 用 户 注册 的 功能 , 并 且 在 表单 中 通过 JavaScript 脚本 对 提交 的 元 素 进 行 判 断 , 最 终 符合 要 求 
后 ， 将 用 户 注 册 信息 添加 到 指定 的 数据 表 中 。 

(1) 创建 index.php 页 面 ， 完 成 用 户 注册 页 面 和 表单 的 设计 。 通 过 JavaScript 对 表单 中 提交 的 值 进行 判断 ， 
并 直接 将 判断 的 结果 反馈 到 div 标签 中 ， 最 终 将 表单 中 的 数据 提交 到 index_ok.php 文件 中 ， 完 成 用 户 注册 的 
操作 。 


<form name="form_ reg" method="post" action="index_ok.php" onSubmit="retumn chkreginfo(form reg,'all)"> 
<t> 
<td height="30"><div align="right"> 密 码 ，</div></td> 
<td height="30" colspan="2" align="left">&nbsp: 
<input type="password" name="pwd" id="pwd" size="30" class="inputcss" 
onBlur="chkreginfo(form reg.1)"> <font color="#FF0000">+</font>&nbsp; 
<div id="chknew_pwd" style="color: #FF0000"></div> 


<td height="30">&nbsp:</td> 
<td width="150" height="30"><input type="image" sre="images/form (2).jpe”> &nbsp:é&nbsp:</td> 
<td width="343"><img sre="images/form jpg" width="72" height="26" 
‘onClick="form reg.reset()" style="cursor: hand" /></td> 
<tr> 
</form> 
(2) 编写 JavaSeript 脚本 ， 创 建 checkjs 脚本 文件 ， 完 成 对 表单 中 提交 的 值 进行 判断 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 数据 添加 到 指定 的 数据 表 中 。 


(4) 创建 conn.php 文件 ， 完 成 MySQL 服务 器 和 MySQL 数据 库 的 连接 操作 ， 并 设置 编码 格式 为 utf-8。 
图 秘笈 心 法 
心 法 领悟 275: 正则 表达 式 的 运用 。 


在 本 实例 中 ， 不 只 一 次 使 用 了 正则 表达 式 ， 分 别 为 通过 正则 表达 式 对 密码 的 强度 进行 判断 ， 对 手机 号 码 进 
行 判断 ， 对 座机 号 码 进 行 判断 以 及 对 邮箱 地 址 进行 判断 。 


Al30d{998|^15Cdf99)S|^189Cd{f8)D)S/ /判断 手机 号 码 
/0d{3})0d{8DsI 0d{4}-)04{7DS0d{4}-)0d{8D)s/ 1/ 判断 座机 号 码 
Nw+([-+. TWH)*@ Wt J ww. J wt)*/ 1/ 判断 邮箱 
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实例 276 


图 实例 说 明 


为 了 防止 用 户 通过 恶意 程序 登录 站 点 ， 提 高 网 站 的 安全 性 ， 项 目 开 发 时 ， 在 用 户 登 录 、 注 册 以 及 发 表 主题 
等 模块 中 加 入 验证 码 模块 是 必 不 可 少 的 。 应 用 验证 码 技术 ， 可 以 有 效 地 防止 用 户 通过 探测 的 方式 非法 登录 ， 从 
而 有 效 地 提高 站 点 的 安全 性 。 在 本 实例 中 ， 应 用 JavaScript 技术 及 0~9 这 10 个 别致 数字 图 片 为 博客 的 后 台 登 录 
设计 验证 码 功能 ， 其 运行 效果 如 图 6.7 所 示 。 


NPE: Er Mrm:FPosg 342 看 下 洁 
9 | 国 到 


图 6.7 数字 图 像 验 证 码 


图 关键 技术 


首先 ， 通 过 JavaScript 中 Math 对 象 的 random0 方 法 随机 生成 4 位 随机 数 ， 并 通过 doument 对 象 的 write0 方 
法 将 这 4 位 随机 数 所 对 应 的 图 片 以 链接 形式 输出 ， 链 接地 址 为 某 PHP 页 面 ， 然 后 ， 通 过 $_GET[] 全 局 数组 提取 
链接 地 址 所 传 入 的 随机 数值 ， 通 过 PHP 文件 操作 函数 读 取 该 随机 数 对 应 的 图 片 ， 并 以 二 进 制 的 形式 输出 到 浏览 
器 。 接 着 ， 定 义 一 个 重新 指定 图 片 链接 地 址 的 方法 ， 当 单 击 “ 看 不 清 ”链接 时 ， 调 用 该 方法 生成 新 的 验证 码 图 
片 。 最 后 , 在 表单 中 添加 一 个 隐藏 域 , 用 于 提交 4 位 随机 数 , 当 用 户 单 击 表单 中 的 “登录 ”按钮 时 , 通过 JavaScript 
将 隐藏 域 的 值 与 验证 码 文本 框 所 输入 的 内 容 进 行 比较 ， 完 成 验证 操作 。 

本 实例 的 关键 技术 主要 是 通过 JavaScript 随机 生成 4 位 随机 数 , 以 及 如 何 将 随机 数 对 应 的 图 片 以 二 进 制 的 形 
式 输出 到 浏览 器 。 

(1) 创建 4 位 随机 数 
通过 JavaScript 中 Math 对 象 的 random0 方 法 随机 生成 4 位 随机 数 ， 关 键 代码 如 下 : 


var num1=Math.round(Math.random()*10000000); 
var num=num1.toString0.substr(0.4); /生成 4 位 随机 数 


(2) 将 图 片 以 二 进 制 形式 输出 

应 用 PHP 的 文件 操作 函数 即 可 实现 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ,本 实例 主要 应 用 ffeadO 函 数 实现 ， 
该 函数 的 语法 如 下 : 

fread ( int handle. int length) 

参数 说 明 : 

handle: fopen0 函 数 打开 文件 后 所 返回 的 文件 句柄 。 

length: 所 读 取 文件 的 长 度 。 

例如 ， 本 实例 中 应 用 fread0 方 法 将 图 片 以 二 进 制 形式 输出 到 浏览 器 ， 实 现代 码 如 下 : 


ee 


ee 
Sfp=fopen($address,"r"): /打开 文件 


echo fread($fp filesize($address)): / 读 取 文件 
图 设计 过 程 


(1) 编写 index.php 用 户 登录 页 面 ， 创 建 表单 ， 在 表单 中 添加 用 户 名 文本 域 、 密 码 域 、 验 证 码 文本 域 以 及 
保存 随机 数 的 隐藏 域 。 

(2) 为 了 提高 网 站 的 安全 性 和 人 性 化 ， 在 用 户 登录 或 注册 表单 中 的 数据 提交 给 服务 器 之 前 ,需要 对 其 进行 
合理 性 验证 。 本 实例 应 用 JS 文件 夹 下 的 funjs 脚本 文件 在 客户 端 对 表单 提交 数据 进行 验证 ， 这 样 可 以 降低 服务 
器 负载 ， 在 实际 项 目 开 发 中 ， 对 一 些 安全 性 要 求 较 高 的 模块 ， 建 议 采 用 客户 端 和 服务 端 双重 验证 ， 这 样 既 可 以 
为 用 户 操作 带 来 方便 ， 还 可 以 保证 系统 的 安全 。 

(3) 编写 JavaScript 脚本 生成 4 位 随机 数 ， 并 且 在 用 户 单 击 “ 看 不 清 ” 链 接 时 ， 设 法 在 不 刷新 页 面 的 情况 
下 动态 改变 这 4 位 随机 数 的 值 。 本 实例 通过 Math 对 象 的 random0 方 法 产生 4 位 随机 数 ， 然 后 通过 自 定义 方法 
code_10 动 态 更 改 验证 码 的 值 。 实 现 该 过 程 的 关键 代码 如 下 : 

<script language="javascript"> 
Var num1=Math.round(Math.random()*10000000); 
Varnumrnuml toStringO).substr(0.4); /产生 4 位 随机 数 


document.write("<img name=codeimg7 src=xym. a um="+num.substr(3,1)+">"): 

form login.xyml.value=num; 

finction code_10{ // 通 过 该 方法 动态 改变 验证 码 的 值 

Var num1=Math.round(Math.random()*10000000); 
Var num=numl.toStringO.substr(0.4); 
documentcodeimg4.src="xym.php?num="+nunm.substr(0,1); 
document.codeimg$.sre="xym.php?num="+num.substr(1,1); 
‘document.codeimg6.src="xym.php?num="+num.substr(2,1); 
document.codeimg7.sre="xym.php?num="+num.substr(3,1); 
form login.xyml.value=num; // 将 验证 码 的 值 赋 给 隐藏 域 

Se 

(4) 创建 xym.php 文件 ， 采 用 PHP 文件 操作 函数 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ， 这 样 可 以 有 效 地 
提高 静态 页 面 与 动态 页 面 之 间 的 交互 性 ， 其 代码 如 下 : 


Snum=$_GET[num]; // 接 收 GET 方法 传递 过 来 的 参数 
Saddress="images/code/". $num.".gif’; // 获 取 图 片 路 径 
Sfp=fopen($address,"r"); /打开 图 片 文件 
echo fread($fp,filesize($address)): // 将 图 片 文件 读 取 到 浏览 器 
felose($fp); 1/ 关闭 打开 的 文件 句柄 

图 秘笈 心 法 


心 法 领悟 276: PHP 标记 的 特性 。 

如 果 在 PHP 页 面 中 ， 不 仅 包含 PHP 代码 ， 而 且 包含 其 他 语言 代码 ， 如 JavaScript、Css 或 Html 等 ， 需 要 书 
写 完整 的 PHP 代码 块 标记 ， 即 “<?php” 与 “?>” 都 要 写 ， 而 若 页 面 代码 完全 由 PHP 构成 ， 则 建议 只 写 开始 标 
记 ， 不 写 结束 标记 ， 这 样 可 以 防止 恶意 用 户 通过 非法 注入 等 手段 在 页 面 代码 后 注入 恶意 代码 。 


图 实例 说 明 


验证 码 不 但 可 以 使 用 数字 图 像 来 完成 ， 而 且 可 以 使 用 中 文 图 像 来 完成 。 为 了 防止 用 户 通 过 恶意 程序 登录 站 
点 ， 提 高 网 站 的 安全 性 ， 在 本 实例 中 将 介绍 如 何 通过 中 文 图 像 来 生成 验证 码 ， 运 行 结果 如 图 6.8 所 示 。 
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| 还 赤 本 管理 登录 
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图 6.8” 中文 图 像 验 证 码 


力 关键 技术 


开发 中 文 图 像 验 证 码 ， 首 先 应 该 确定 所 使 用 的 文字 ， 并 且 将 文字 制作 成 图 片 ， 以 数字 进行 命名 。 然 后 ， 将 
所 使 用 的 文字 定义 到 数组 中 。 最 后 ， 计 算出 数组 中 元 素 的 长 度 值 ， 并 应 用 randO 函 数 从 这 个 长 度 值 中 随机 取 值 ， 
根据 随机 取 值 输出 对 应 的 中 文 图 像 ， 即 验证 码 ， 其 关键 代码 如 下 : 


<?php 
S$str = array ("大 ", "更 ", " 创 ", "天 ", " 科 ", " 客 ", " 博 ", " 技 ", " 立 ", "新 "); // 定 义 中 文字 符 串 的 数组 
$word = count ( $str ); // 计 算出 数组 中 元 素 个 数 
for($i=0; $i< 4; Si++) { /执行 for 循环 ,以 数组 中 元 素 个 数 为 范围 随机 取出 4 个 值 
Snum = rand ( 0, $word - 1 ); //Sword=$word*2-1 /随机 取 值 
/输出 随机 取出 的 4 个 值 对 应 的 中 文 图 片 
Simg = $img . "<img src= images/checkcode/" . Snum . ".gif width="16' height="16>"; /显示 随机 图 片 
Spic = $pic . $str [$num]; /将 图 片 转换 成 数组 中 的 文字 
} 
> 

国 设计 过 程 


(1) 编写 index.php 用 户 登录 页 面 ， 创 建 表单 ， 在 表单 中 添加 用 户 名 文本 域 、 密 码 域 、 验 证 码 文本 域 以 及 
保存 随机 数 的 隐藏 域 。 

(2) 在 index.php 页 面 中 ， 编 写 PHP 脚本 ， 定 义 验 证 码 所 使 用 的 中 文字 符 串 ， 并 生成 验证 码 ， 其 关键 代码 
请 参考 本 实例 的 关键 技术 。 

(3) 本 实例 中 沿用 实例 276 中 对 表单 中 元 素 进行 验证 的 方法 ，funjs 脚本 文件 同样 存储 于 js 文件 夹 中 。 

(4) 创建 checkuser.php 文件 ， 完 成 对 用 户 提交 的 登录 信息 的 验证 。 


图 秘笈 心 法 
心 法 领悟 277， 如 何 计算 数组 中 元 素 的 数目 。 
在 本 实例 中 ,应 用 count 0 函数 计算 数组 中 元 素 的 数目 。 注意 ,count0 函 数 只 适用 于 计算 数组 中 元 素 的 个 数 ， 


如 果 将 其 应 用 到 其 他 类 型 的 数据 中 ， 那 么 返回 值 只 有 一 个 单元 。 如 果 要 计算 字符 串 的 长 度 ， 那 么 要 使 用 stlen0 
函数 ， 切 记 strlen0 函 数 不 可 对 数组 元 素 进行 操作 ， 虽 然 不 返回 错误 信息 ， 但 是 返回 的 结果 是 不 准确 的 。 


力 实例 说 明 
上 传 图 片 是 一 个 比较 常见 的 功能 ， 但 是 在 输出 上 传 图 片 时 可 能 会 遇 到 一 些 问题 ， 由 于 上 传 图 片 的 大 小 没有 


a 
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固定 ， 从 而 导致 图 片 在 输出 时 变形 ， 这 是 一 个 很 让 人 伤 脑筋 的 问题 。 如 果 在 上 传 图 片 时 直接 将 其 生成 一 个 固定 
大 小 的 缩 略图 ， 并 同时 保存 上 传 的 原始 图 片 ， 那 么 在 输出 时 就 不 会 有 任何 问题 。 

在 本 实例 中 就 实现 了 这 样 一 个 功能 ， 即 在 将 图 片上 传 到 服务 器 的 同时 ， 生 成 图 片 的 缩 略 图 ， 浏 览 的 是 图 片 
的 缩 略图 ， 而 如 果 要 下 载 ， 则 下 载 的 仍 是 原始 图 片 。 本 实例 的 运行 效果 如 图 6.9 所 示 。 


图 片 T 图 片 5 图 片 5 


图 片 图 片 图 片 2 


图 6.9 缩 略图 艺术 库 


图 关键 技术 


在 本 实例 中 ， 有 关 多 图 片 的 任意 上 传 和 图 片 的 分 页 输出 不 再 是 讲解 的 重点 ， 如 果 读 者 要 了 解 这 方面 的 内 容 ， 
请 参考 本 书 第 4 章 的 内 容 。 
本 实例 重点 讲解 的 是 如 何 生成 图 片 的 缩 略图 ， 并 且 为 缩 略 图 添加 水 印 ， 其 原理 如 下 : 
(1) 通过 GetImageSizeO) 函 数 获取 上 传 图 片 的 信息 ， 包 括 大 小 、 类 型 等 ， 并 根据 其 类 型 ， 新 建 一 个 对 应 类 
getimagesize() 函 数 ， 获 取 指 定 图 像 的 大 小 ， 语 法 如 下 : 
array getimagesize ( string filename [, array &imageinfo] ) 
getimagesize() 函 数 将 测定 任何 GIF、JPG、PNG、SWF、SWC、PSD、TIFF、BMP、IFF、JP2、JPX、JB2、 
JPC、XBM 或 者 WBMP 图 像 文 件 的 大 小 ， 并 返回 图 像 的 尺寸 以 及 文件 类 型 和 一 个 可 以 用 于 普通 HTML 文件 
中 <IMG> 标记 中 的 height/width 文本 字符 串 ， 其 返回 值 是 一 个 具有 4 个 单元 的 数组 : 
索引 0 包含 图 像 宽 度 的 像素 值 ; 
索引 1 包含 图 像 高 度 的 像素 值 ; 
索引 2 是 图 像 类 型 的 标记 : 1= GIF，2 =JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP, 7= TIFF(intel 
byte order), 8 = TIFF(motorola byte order), 9 = JPC, 10 = 卫 2, 11 = JPX, 12 = 了 2, 13 = SWC, 14 = IFF， 
15=WBMP，16=XBM。 
回 索引 3 是 文本 字符 串 ， 内 容 为 height="yyy" width="xxx"， 可 直接 用 于 IMG 标记 。 

如 果 参 数 flename 指定 的 图 像 不 存在 或 者 其 不 是 有 效 的 图 像 ， 将 返回 FALSE 并 产生 一 条 E_WARNING 
级 的 错误 。 
(2) 对 上 传 图 片 的 大 小 与 指定 缩 略 图 的 大 小 进行 比较 ， 看 其 是 否 需要 创建 缩 略 图 。 

(3) 根据 判断 结果 应 用 imagecopyresampled() 函 数 重新 生成 新 的 图 像 。 
imagecopyresampled0) 函 数 ， 从 原 图 像 中 采样 ， 复 制 部 分 图 像 ， 重 新 生成 图 像 ， 语 法 如 下 : 


bool imagecopyresampled ( resource dst_image. resource sre_image. int dst_ x. int dst_y. int sre_x, int sre_y, int dst_w. int dst_h, int sre_w, int sre_h ) 


imagecopyresampledO 函 数 将 一 幅 图 像 中 的 一 块 正方 形 区 域 复 制 到 另 一 个 图 像 中 ， 平 滑 地 插入 像素 值 ， 在 减 
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小 图 像 大 小 的 同时 ， 仍 然 保持 了 极 大 的 清晰 度 。 

参数 说 明 : 

dst_image: 目标 图 像 标识 符 ; 

src_image: 源 图 像 标识 符 。 

如 果 源 和 目标 的 宽度 和 高 度 不 同 ， 则 会 进行 相应 的 图 像 收缩 和 拉 伸 。 坐 标 指 的 是 左上 角 。 本 函数 可 用 来 在 
同一 幅 图 内 部 复制 (如 果 dst_image 和 src_image 相同 的 话 ) 区 域 ， 但 如 果 区 域 交 迭 的 话 则 结果 不 可 预知 。 

如 果 成 功 则 返回 TRUE， 失 败 则 返回 FALSE。 


< 注意 : 本 函数 需要 GD 库 2.0.1 版 或 者 更 高 版 本 的 支持 。 


(4) 为 重新 生成 的 图 像 添 加 水 印 ， 可 以 选择 文字 水 印 或 者 图 像 水 印 。 

添加 文字 水 印 应 用 ImageTTFTextO 函 数 ， 如 果 页 面 使 用 的 不 是 utf-8 编码 ， 那么 还 要 对 水 印 文字 的 编码 格式 
进行 转换 ， 因 为 ImageTTFText0 函 数 只 支持 utf-8 编码 。 

添加 图 像 水 印 应 用 imagecopy0 函 数 ， 完 成 对 图 像 的 复制 操作 。 
图 设计 过 程 

缩 略图 艺术 库 沿 用 了 第 4 章 中 实例 229 通过 header 函数 进行 下 载 的 内 容 ， 在 此 基础 上 增加 上 传 图 片 生成 缩 
略图 的 功能 ， 有 关上 传 和 下 载 这 里 不 再 鳌 述 。 

(1) 在 上 传 文件 的 处 理 页 index_ok.php 中 ， 包 含 了 一 个 thumbnailphp 文件 ， 重 新 定义 上 传 文件 的 类 型 ， 

并 重新 指定 上 传 文件 的 存储 位 置 ， 定 义 原始 文件 存储 文件 夹 和 缩 略 图 存储 文件 夹 ， 在 通过 move_uploaded file0 
函数 完成 文件 的 上 传 操作 后 ， 调 用 thumbnail.php 文件 中 包含 的 方法 makethumb0 将 上 传 的 图 片 生成 缩 略 图 ， 并 
添加 文字 水 印 。 这 是 在 index_ok.php 文件 中 所 作 的 处 理 ， 其 关键 代码 如 下 : 


<?php 
header ( "Content-type: texVhtml; charset=UTF-8" ); /设置 文件 编码 格式 


if($ POST [filesl !="") { 

$data = date ( "Y-m-d H:m:s" ):; 

function check($var) { /验证 数组 的 返回 值 是 否 为 空 
return (Svar !=""); 

} 


Sfiles = array_filter ( $_POST ["files"], "check" ): // 去 除数 组 中 空 值 
Sarray = array_filter ( $_FILES ["picture"] ["name"]. "check" ); // 去 除数 组 中 空 值 
foreach ( $array as $key => $value ) { /循环 读 取 数组 中 数据 
Stypes = strtolower ( strstr ( Svalue.…) ); /截取 上 传 文件 的 后 级 
if ($types 一 "jpg" | $types — ".gif" || $types — ".png") { /判断 上 传 文件 的 后 组 是 否 符合 要 求 
Sthumbnail = ‘thumbnail/’; 
Soriginal = 'original/’; 
Sfile name = time 0 . $key . strtolower ( strstr ( Svalue. "." ) ); /定义 上 传 文件 名 称 
Spath = Soriginal . $file_name; /定义 原始 文件 的 存储 位 置 
Spath_thumbnail = $thumbnail . $file name: /定义 缩 略 图 的 存储 位 置 
move_uploaded file ( $_FILES ["picture"] ["tmp_name"] [Skey]. $path ); 1/ 执行 上 传 操作 
makethumb ( $path, $path_thumbnail, "200", "200", "100", "www.mrbccd.com” ); // 生 成 缩 略图 


S$query = "insert into tb up file (file testpath thumbnail.data.file_name) values (‘$path','$path_thumbnail.'S$data','$files[$key])": 
Sresult = mysql_ query ( $query ): 
}elsef 
echo "上 传 文件 " . $value . "类 型 不 正确 ! "; 
有 . 
echo "<script>alert( 图 片上 传 成 功 ): window.location.href='index.html':</script>"; 
} 
> 


(2) 编写 了 humbnail.php 文件 ， 定 义 makethumb0 方 法 ， 完 成 缩 略 图 的 生成 和 水 印 的 添加 操作 。 自 定义 方法 
makethumb() 的 语法 如 下 : 
makethumb($srcFile, $dstFile. $dstW., $dstH, Srmate = 100, Smarkwords = null. Smarkimage = null){} 
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参数 说 明 : 

$srcFile: 图 片 文 件 名 ; 

$dstFile: 另存 文件 名 ; 

$markwords: 水 印 文字 ; 

$markimage: 水 印 图 片 ; 

$dstW: 图 片 保 存 宽度 ; 

$dstH: 图 片 保存 高 度 ; 

$rate: 图 片 保 在 品质， 默认 值 为 100。 

有 关 thumbnail.php 文件 的 完成 代码 请 参考 本 书 光 盘 。 

秘笈 心 法 

心 法 领悟 278: 定义 缩 略 图 的 好 处 。 

运用 缩 略图 技术 ， 可 解决 图 片 输出 时 的 变形 问题 ， 无 论 是 否定 义 输出 图 片 的 大 小 ， 它 都 将 以 一 个 相同 的 尺 
十 进行 输出 ， 使 页 面 更 加 规范 、 美 观 ， 同 时 也 避免 了 输出 图 片 的 拉 伸 变形 。 


级 
趣味 指数 : odobolodol 


ay 


实例 说 明 


EXIF 信息 是 指 由 数码 相机 在 拍摄 过 程 中 采集 一 系列 的 信息 ， 然 后 把 信息 放置 在 JPEG/TIFF 文件 的 头 部 ， 
也 就 是 说 EXIF 信息 是 镶嵌 在 JPEG/TIFF 图 像 文 件 格式 内 的 一 组 拍摄 参数 ， 主 要 包括 摄影 时 的 光圈 、 快 门 、 
ISO、 日 期 时 间 等 各 种 与 当时 摄影 条 件 相关 的 讯息 ， 以 及 相机 品牌 型 号 、 色 彩 编码 、 拍 摄 时 录制 的 声音 和 全 球 定 
位 系统 (GPS) 等 信息 。 既 然 在 EXIF 中 包含 了 如 此 详细 和 完整 的 信息 ， 那 么 在 PHP 中 应 该 如 何 获取 到 这 些 信 
息 呢 ? 这 就 是 本 实例 将 要 介绍 的 技术 一 一 获取 并 输出 图 像 的 EXIF 信息 ， 其 运行 结果 如 图 6.10 所 示 。 
1 加 


六 位 名 : 127D3270723jpg 文件 名 : 12793270732jFg 文件 名 : L2792070731 ipg 立体 名 : 127932T0731 jpr 
I + 01005:2103293 onid : 20100622 1032:14 。。 扯 拓 时间 : 20100622103426 。。 拍 捅 F 间 : 20102627102428 


文件 名 : 12793270130jpg 


文 和 各 : 1279326p952j 文件 名 : 12792269951 pe 文 了 各， 1279336513t jpg 
拍 所 时 间 : 20100622103329 Rid : 20100622 103237 近期 时 间 : 20100622102322 


a : 20100623 0 35333 


图 6.10 提取 图 像 的 EXIF 信息 


图 关键 技术 


在 PHP 中 ， 获 取 EXIF 信息 应 用 的 是 EXIF 函数 库 中 的 函数 。 首 先 ， 应 该 确定 EXIF 函数 是 否 已 经 加 载 ， 在 
php.ini 文件 中 查看 extension=php_exif dll 前 是 否 有 分 号 “:”， 如 果 有 则 说 明 未 加 载 ， 要 将 分 号 去 掉 。 
同时 还 要 注意 extension=php_exif.dll 项 的 存储 位 置 ， 必 须 放置 在 extension=php_ mbstring.dll 项 之 后 ， 和 否则 
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EXIF 函数 是 不 被 支持 的 。 设 置 完成 后 保存 php.ini 文件 ， 并 重新 启动 Apache 服务 器 。 在 本 实例 中 ， 具 体 应 用 的 
是 EXIF 函数 库 中 的 exif read_data0 函 数 ， 获 取 图 像 的 EXIF 信息 。 


exif read data0) 函 数 ， 从 JPEG 或 TIFF 文件 中 读 取 EXIF 头 信息 ， 其 语法 如 下 : 
array exif read data ( string filename [, string sections [, bool arrays [. bool thumbnail]]] ) 


参数 说 明 : 
filename: 被 读 取 的 图 像 文件 名 ， 不 可 以 是 URL。 
sections: 定义 存在 于 文件 中 的 逗号 分 隔 的 区 段 列表 ， 用 来 产生 结果 数组 。 如 果 未 找到 所 请 求 的 区 段 则 返回 
值 为 FALSE。 所 包含 的 区 段 如 表 6.1 所 示 。 
表 6.1 exif_read_data() 函 数 中 参数 sections 包含 的 区 段 
区 段 名 称 包含 内 容 、 说 明 
FILE FileName、 FileSize、FileDateTime、SectionsFound 
html、Width、Height、IsColor、 可 能 有 更 多 其 他 的 。Height 和 Width 是 用 和 getimagesize0 一 样 的 方 
COMPUTED ”| 法 计算 的 ， 因 此 它们 的 值 不 能 是 任何 返回 的 头 信息 的 部 分 ，html 是 一 个 height/width 文本 字符 申 ， 可 
以 用 于 普通 的 HTML 中 
ANY TAG 任何 包含 有 标记 的 信息 ， 例 如 下 D0、EXIF 等 
IFD0 所 有 IFD0 的 标记 数据 。 在 标准 的 图 像 文 件 中 包含 了 图 像 大 小 及 其 他 
THUMBNAIL | 如 果 有 第 二 个 FD， 文 件 应 该 包含 有 缩 略 图 。 所 有 有 关 嵌 入 缩 略图 的 标记 信息 都 存储 在 本 区 
COMMENT JPEG 图 像 的 注释 头 信息 
EXIF EXIF 区 段 是 IFDO 的 子 区 ， 包 含有 图 像 的 更 多 详细 信息 。 大 多 数 内 容 都 是 数码 相机 相关 的 


arrays: 指定 是 否 每 个 区 段 都 成 为 一 个 数组 。sections COMPUTED、THUMBNAIL 和 COMMENT 区 段 总 


是 成 为 数组 ， 


thumbnail 


exif read 4 


的 数据 ， 将 返 


因为 它们 里 面包 含 的 名 字 和 其 他 区 段 冲突 。 
: 如 果 该 值 为 TRUE， 读 取 缩 略图 本 身 ， 否 则 只 读 取 标记 数据 。 


data0 函 数 的 返回 值 是 一 个 关联 数组 ， 键 名 是 头 信息 名 ， 值 是 与 其 对 应 的 数据 。 如 果 没有 可 供 返 回 


回 FALSE。 


力 设计 过 程 


本 实例 沿用 缩 略 图 艺术 库 中 的 内 容 ， 实 现 多 图 片 的 上 传 和 分 页 输出 ， 并 且 为 上 传 的 图 片 生 成 缩 略图 。 在 分 


页 输出 上 传 图 


片 时 ， 运 行 自 定义 函数 GetImageInfo0 获 取 图 片 的 EXIF 信息 ， 并 且 输 出 图 片 的 名 称 和 拍摄 时 间 。 


(1) 在 index.php 页 面 中 ,实现 上 传 图 片 的 分 页 输出 , 并 且 包含 exifphp 文件 ,调用 自 定义 函数 GettmageImfo0 
获取 图 片 的 EXIF 信息 ， 输 出 图 片 的 名 称 和 拍摄 时 间 ， 其 关键 代码 如 下 : 
<2php 


include "exif php"; // 包 含 exifphp 文件 
Spic=GetImageInfo($myrow[file_test]):; /调用 getimageinfo0 方 法 ， 获 取 原始 图 片 的 EXIF 信息 
echo "文件 名 : ".$pic[ 文 件 名 ]."<br>"; /输出 图 片 名 称 

echo ”拍摄 时 间 :".$pic[' 拍 摄 时 间 "]; /输出 拍摄 时 间 

> 


(2) 创建 exifphp 文件 。 编 写 自 定义 函数 getimageinfo0， 应 用 exif read_data0 函 数 获取 指定 图 片 的 EXIF 
信息 ， 其 关键 代码 如 下 : 


<?php 
function GetImageInfo(Simg) { 
Simgtype = array ("" "GIF", "JPG", "PNG", "SWEF", "PSD" "BMP" ); 
S$Orientation = array (", "top left side", "top right side”, "bottom right side" ); 
$ResolutionUnit = array (""."". "英寸 ". "厘米 " ); 
Sexif = exif read_data ( Simg, "IFDO" ); 
if ($exif — false) { 


Snew_img info =array ("文件 信息 "=> "没有 图 片 EXIF 信息 "): 
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}else{ 

Sexif = exif read data ( $img., 0. true ); 

Snew_img info =array ("文件 名 " => Sexif [FILE] [FileName], "时 间 截 " => date ( "Y-m-d His", Sexif [FILE] [FileDateTime] ); 
3 
Teturn $new_img_info; 


} 

2 

有 关 本 实例 的 其 他 内 容 ， 由 于 篇 幅 所 限 ， 请 参考 本 书 光盘 ， 这 里 不 再 袭 述 。 
国 秘笈 心 法 


心 法 领悟 279: 通过 表单 中 的 隐藏 域 控 制 上 传 文件 的 大 小 。 

在 对 上 传 的 文件 进行 判断 时 ， 如 果 应 用 $_FILES[picture]['error] 对 上 传 信息 进行 判断 ， 当 其 返回 值 为 2 时 ， 
说 明 上 传 文件 的 大 小 超出 表单 中 约定 的 范围 ， 而 表单 中 的 这 个 约定 值 是 通过 隐藏 域 MAX FILE_SIZE 的 值 来 控 
制 的。 在 设置 这 个 隐藏 域 时 ， 必 须 将 隐藏 域 放 置 在 文件 域 之 前 ， 否 则 不 起 作用 。 


6.2 控制、 显示 图 片 特性 


在 网 页 中 适当 地 应 用 一 些 动态 图 片 特效 ， 不 仅 可 以 使 整个 页 面具 有 更 大 的 视觉 冲击 力 ， 还 可 以 使 页 面具 有 
温 座 感 ， 最 终 达到 提高 网 站 访问 量 的 目的 。 
初级 


实例 289 地 呆 指 雪夫 容重 


力 实例 说 明 

为 了 合理 利用 网 页 空间 ， 在 网 页 设计 时 会 缩小 某 些 图 片 的 实际 尺寸 ， 但 这 样 可 能 导致 浏览 者 看 不 清 图 片 的 
内 容 ， 为 了 解决 上 述 问 题 ， 可 以 通过 鼠标 滑轮 改变 图 片 的 大 小 。 运 行 本 实例 ， 将 显示 如 图 6.11 所 示 的 页 面 ， 将 
鼠标 指针 放 到 图 片上 ， 通 过 滚动 鼠标 滑轮 即 可 改变 图 片 的 大 小 。 


通过 鼠标 改变 图 像 大 小 


各 a 


赤 大 
周 寺 ” 厂 厂 厂 辐 RW 4 


到 


6.11 通过 鼠标 滑轮 控制 图 片 大 小 


图 关键 技术 


本 实例 主要 通过 调用 自 定义 函数 change_img10 和 自 定 义 函 数 change_img20 实 现 图 片 的 大 小 改变 ， 并 通过 
onmousewheel 事件 调用 这 两 个 函数 。 
onmousewheel 事件 用 于 调用 handlerText 所 代表 的 Javascript 方法 ， 语 法 如 下 : 
onmousewheel—"handlerText™” 
图 设计 过 程 
(1) 在 页 面 中 插入 两 副 图 片 ， 并 通过 这 两 副 图 片 的 onmousewheel 事件 调用 函数 change img10 和 函数 
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change_img20， 代 码 如 下 : 
<img id—"img" ste—"images/image.gif" width-"60" height-"60" onmousewheel-"change img1(this)"/> 
<img id—"img" ste—"images/image.gif" width-"60" height-"60" onmousewheel-"change img2(this)"/> 
(2) 编写 函数 change_ img10 和 函数 change_img20 改 变 图 片 的 大 小 ， 代 码 如 下 : 
<scriptlanguage="javascript > 
function change img1(x) { 
i 


xX.height=x.height+10; 
if(x» a height—1000) 泪 


ss 
} 
function change img2(x) { 
X.Width= x.width-10; 
x.height=x.height-10; 
这 x.width 一 0|x.height 一 0) { 
xXx.width=60; 
x.height=60; 
} 


} 
</script> 


图 秘笈 心 法 


心 法 领悟 280: 图 片 特效 的 扩展 。 
本 实例 介绍 的 是 通过 鼠标 滑轮 控制 图 片 的 大 小 ， 依 据 此 原理 ， 还 可 以 实现 图 片 放大 镜 的 功能 ， 通 过 倍数 来 
控制 图 片 的 大 小 。 


站 
| 


| Ce 


力 实例 说 明 


在 用 户 登 录 页 面 或 留言 发 表 页 面 经 常会 看 到 验证 码 的 身影 , 通过 这 项 技术 可 以 很 大 程度 提高 网 站 的 安全 性 。 
运行 本 实例 ， 可 以 发 现在 如 图 6.12 所 示 的 登录 页 面 中 随机 产生 了 4 位 数字 (6191) ， 每 次 刷新 页 面 这 4 位 数字 
都 会 发 生 改变 ， 用 户 登 录 时 必须 输入 这 4 位 数字 ， 这 样 可 以 防止 用 户 通过 恶意 程序 来 试探 登录 密码 的 值 从 而 非 
法 登录 网 站 。 


图 6.12 显示 随机 图 像 


图 关键 技术 


应 用 PHP 的 随机 函数 mt_randO0 生 成 随机 验证 码 , 根据 随机 验证 码 的 值 读 取 对 应 的 数字 图 片 ， 生 成 验证 码 
图 像 。 
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mt rand0 函 数 ， 用 于 产生 min 和 max 之 间 的 随机 数 ， 语 法 如 下 : 
int mt_rand([int min].[int max]) 
参数 min 和 max 指定 随机 数 的 取 值 范围 。 
在 读 取 生 成 的 随机 验证 码 时 ， 应 用 到 for 语句 和 substr0 函 数 对 验证 码 的 值 进行 读 取 ， 根 据 读 取 的 值 定义 输 
出 的 数字 图 像 ， 其 关键 代码 如 下 : 


<?php 
S$num = intval ( mt_rand ( 1000. 9999 ) ); /生成 随机 验证 码 
for($i=0: $i<4; $i++) { /循环 读 取 验证 码 
echo "<img src=images/code/" . substr ( strval ( Snum ). $i 1 ) .".gif>"; /输出 数字 图 像 
过 } 
图 设计 过 程 


(1) 创建 用 户 登录 页 面 ， 添 加 用 户 登录 表单 。 
(2) 创建 JavaScript 脚本 ， 定 义 chkuserinput0 方 法 对 表单 中 提交 的 数据 进行 验证 。 
<script language="javascript"> 
function chkuserinput(form){ 
if(form.username.value—""){ 
alert( 请 输入 用 户 名 !); 


if(form.userpwd.value—"") 
alert(" 请 输入 用 户 人 2 
form.userpwd.selectO; 
Teturn(false): 


} 
if(form.yz.value—""){ 
alert(" 请 输入 验证 码 !"); 
form.yz.select():; 
return(false); 
return(true); 
</script> 
(3) 编写 PHP 脚本 ， 通 过 mt_rand0 函 数 生成 4 位 随机 验证 码 ， 并 输出 4 位 随机 验证 码 对 应 的 图 片 。 


图 秘笈 心 ; 


尾 法 领情 281: mt rand0 函 数 的 应 用 。 
通过 mt_rand0 函 数 获取 随机 数 不 但 可 以 用 于 验证 码 的 生成 ， 还 可 以 应 用 到 随机 抽奖 或 者 随机 抽取 考题 的 程 
序 中 。 其 应 用 的 原理 都 是 相同 的 ， 如 果 读 者 感 兴趣 可 以 亲自 体验 一 下 。 


力 实例 说 明 
在 开发 Web 项 目 中 ,经 常 需要 准确 地 获取 图 像 的 尺寸 以 达到 精确 定位 MR,,,. 
的 目的 。 运 行 本 实例 ， 将 显示 如 图 6.13 所 示 的 页 面 ， 生 成 该 页 面 的 同时 程序 明日 科技 


会 计算 出 页 面 中 图 像 的 高 度 和 宽度 ， 以 便于 开发 人 员 实现 对 图 片 的 定位 。 a 
图 关键 技术 图 6.13 获取 图 像 的 实际 尺寸 
PHP 中 获取 图 像 的 大 小 应 用 getimagesize0 函 数 。 该 函数 用 于 获取 图 片 的 实际 尺寸 ， 其 语法 如 下 : 
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array getimagesize ( string fillename [ array imageinfo]) 
getimagesize(0) 函 数 返回 一 个 具有 4 个 单元 的 数组 ， 包 括 : 
索引 0: 图 像 宽度 的 像素 值 ; 
索引 1: 图 像 高 度 的 像素 值 ; 
索引 2: 图 像 类 型 的 标记 : 1 = GIF, 2=JPG, 3 =PNG, 4=SWF, 5=PSD, 6 = BMP, 7=TIFF(intel byte 


order),8=TIFF(motorola byte order), 9= JPC, 10=JP?2, 11=JPX, 12= JB2, 13= SWC, 14= IFF, 
15= WBMP, 16= XBM. 


索引 3: 文本 字符 串 ， 内 容 为 height="yyy" width="xxx"， 可 直接 用 于 <img> 标记 。 
图 设计 过 程 

本 实例 主要 利用 getimagesize0 函 数 获取 图 片 的 实际 尺寸 ， 代 码 如 下 : 

Saree mineiotipe 


图 秘笈 心 法 

心 法 领悟 282: getimagesize0 函 数 的 妙用 。 

虽然 本 实例 只 是 对 getimagesize0 函 数 的 语法 、 基 本 功能 进行 了 讲解 ， 也 许 并 未 发 现 它 什么 特殊 之 处 ， 功 能 
也 不 过 如 此 ， 但 是 当 你 再 次 回顾 前 面 讲解 的 缩 略 图 艺术 库 和 提取 图 像 的 EXIF 信息 两 个 实例 时 ， 你 就 会 发 现 这 
个 函数 的 重要 性 。 


实例 283 


实例 说 明 


在 图 片 信息 较 多 的 网 页 中 ， 通 过 图 像 手 动 播放 的 方式 显示 图 片 ， 不 仅 可 以 节省 页 面 空间 ， 而 且 可 以 使 浏览 
者 自主 选择 喜爱 的 图 片 进行 显示 。 运 行 本 实例 ， 浏 览 者 可 以 通过 如 图 6.14 中 所 示 的 “ 左 ” 和 “ 右 ” 文 字 超 链接 
浏览 所 有 图 片 。 
明日 图 书 在 线 


侠 设 为 首页 加 履 蕊 本 站 中 联系 我 们 


PHP 
观 目 开发 全 各 实录 


图 6.14 ”获取 图 像 的 实际 尺寸 


图 关键 技术 


本 实例 主要 应 用 onclick0 事 件 调用 JavaScript 脚本 中 的 方法 ， 完 成 图 像 的 手动 播放 操作 ， 在 JavaScript 中 定 
义 了 toleft0 和 toright0 两 个 方法 ， 其 代码 如 下 : 
<script language—"javascript"> 
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function toleftO{ 
这 demol.offsetWidth-demo scrollLeft<=0) 
demo.scrollLeft=0 
else 
demo.scrollLeft=demo.scrollLeft+10; 
} 
function torightO{ 
这 demol.offsetWidth-demo.scrollLeft<=0) 
demo.scrollLeft-0 
else 
demo.scrollLeft=demo.scrollLeft-10; 


图 设计 过 程 
(1) 设计 网 页 的 页 面 ， 定 义 <div> 标 签 和 插入 手动 播放 的 图 像 。 
(2) 编程 控制 图 像 播 放 的 JavaScript 脚本 。 
(3) 在 超 链 接 中 通过 onclick0 事 件 完成 对 JavaScript 脚本 中 方法 的 调用 ， 其 关键 代码 如 下 : 


<td width="100"><div align="left"><a href="#" onclick="toleftO"> 左 </a></div></td> 
<td width="100"><div align="right"><a href="#" onclick="torightO"> 右 </a></div></td> 


图 秘笈 心 法 


心 法 领悟 283: 图 像 手 动 播放 的 好 处 。 
虽然 图 像 的 手动 播放 没有 图 像 自 动 播放 灵活 ， 但 是 ， 手 动 播 放 的 最 大 优点 是 可 以 定位 网 页 中 播放 的 内 容 ， 
而 自动 播放 却 不 能 对 其 进行 定位 ， 只 能 不 停 地 循环 播放 。 


力 实例 说 明 


图 像 的 自动 播放 不 仅 可 以 增添 Web 页 面 的 动态 效果 ， 而且 可 以 节省 网 页 空间 ， 有 效 地 保证 在 有 限 的 页 面 中 
显示 更 多 的 图 片 。 运 行 本 实例 ， 如 图 6.15 所 示 ， 图 像 将 从 右 向 左 自动 播放 。 


PHP 
项 目 开发 全 重奖 了 


图 6.15 图像 的 自动 播放 


图 关键 技术 

本 实例 主要 应 用 setInterval0 函 数 ， 在 指定 的 时 间 间 隔 time 内 调用 函数 方法 ， 完 成 图 像 的 自动 播放 操作 。 
setInterval0 函 数 的 语法 如 下 : 

setInterval(fanctiontime) 
图 设计 过 程 

(1) 设计 网 页 的 页 面 ， 定 义 <div> 标 签 和 插入 手动 播放 的 图 像 ， 其 代码 如 下 : 
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<div id="demo" style="OVERFLOW: hidden: WIDTH: 740px: HEIGHT: 176px" > 
<table cellspacing="0" cellpadding="0" align—"center" border="0"> 

id="demo1">&nbsp; 
<img height="175" ste="images/1.bmp" width="143" border="0" />&nbsp:; 

ta> 
<td id="demo2"></td> 

A> 
</table> 
<div> 

(2) 编程 控制 图 像 自动 播放 的 JavaScript 脚本 ， 并 应 用 setInterval0 函 数 完成 对 Marquee0 方 法 的 调用 ， 其 
代码 如 下 : 


demo.scrollLeft-0 


Var MyMar=setInterval(Marquee,speed) 
demo.onmouseover=function() {clearInterval(MyMar)} 
demo.onmouseout=function() {MyMar=setInterval(Marquee,speed)} 
</SCRIPT> 


图 秘笈 心 法 
心 法 领悟 284: 图 像 自动 播放 的 控制 。 
对 于 图 像 的 自动 播放 , 我 们 可 以 不 了 解 其 具体 是 如 何 运 作 的 ， 只 要 明确 它 调 用 的 方法 , 定义 <div> 标 签 的 ID 
以 及 传递 正确 的 时 间 间 隔 ， 即 可 完成 图 像 的 自动 播放 功能 。 
| ， 
中 级 | 
趣味 指数 : 会 依依 从 


实例 说 明 


图 像 大 小 的 调整 对 于 专业 的 美工 或 者 网 页 设计 者 来 说 不 算 什么 ， 但 是 对 于 程序 员 来 说 ， 特 别 是 那些 不 善于 
处 理 图 片 的 程序 员 来 说 ， 是 一 个 非常 头疼 的 问题 。 虽说 图 片 处 理 不 在 程序 员 的 工作 范围 之 内 ,但 是 有 些小 问题 ， 
还 是 自己 解决 更 好 。 在 本 实例 中 ， 向 程序 员 介 绍 一 种 方法 ， 通 过 我 们 编写 的 程序 实现 对 图 像 大 小 的 任意 调整 。 
运行 本 实例 ， 在 上 传 图 片 的 右 侧 ， 选 择 要 调整 图 片 的 大 小 比例 ， 然 后 单 击 “ 调 整 图 像 大 小 ”按钮 ， 运 行 结果 如 
图 6.16 所 示 。 


图 6.16 ”任意 调整 图 像 的 大 小 
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图 关键 技术 


任意 调整 上 传 图 片 大 小 方法 实现 的 原理 : 首先 ， 根 据 表单 中 提交 的 值 ， 获 取 指 定 图 片 的 存储 路 径 和 名 称 ， 
以 及 它 要 被 调整 的 比例 。 然后， 应 用 getimagesize0 函 数 获取 指定 图 片 的 数据 。 接 着 ， 定 义 thumb0 方 法 ， 根 据 原 
始 图 片 的 数据 和 提交 的 调整 比例 数据 ， 判 断 是 根据 比例 缩放 ， 还 是 进行 裁剪 。 最 后 ， 载 入 原始 图 片 ， 并 定义 新 
的 缩 略图 ， 应 用 ImageCopyResampledO 函 数 将 原始 图 像 复 制 到 新 的 缩 略图 中 ， 并 将 新 的 图 像 存储 到 指定 位 置 。 
imagecopyresampled0 函 数 ， 从 原 图 像 中 采样 ， 复 制 部 分 图 像 ， 重 新 生成 图 像 ， 详 情 请 参见 实例 278。 
op 同样 实现 图 像 的 复制 操作 ， 语 法 如 下 : 


bool imagecopyresized ( resource dst_image, resource src_image, int dst_x, int dst_y, int src_X, int src_y, int dst_w, int dst_h, int sre_w, int src h ) 


imagecopyresized0 函 数 将 一 幅 图 像 中 的 一 块 正方 形 区 域 复制 到 另 一 个 图 像 中 。 

参数 说 明 : 

dst_image: 目标 图 像 标识 符 ; 

src_image: 源 图 像 标识 符 。 

如 果 源 和 目标 的 宽度 和 高 度 不 同 ， 则 会 进行 相应 的 图 像 收缩 和 拉 伸 。 坐 标 指 的 是 左上 角 。 本 函数 可 用 来 在 
同一 幅 图 内 部 复制 (如 果 dst_image 和 src_image 相同 的 话 ) 区 域 ， 但 如 果 区 域 交 迭 的 话 则 结果 不 可 预知 。 


< 注意 : 因为 调 色 板 图 像 的 限制 (255+1 种 颜色 ) ， 存 在 一 个 问题 。 重 新 采样 或 过 滤 图 像 通常 需要 多 于 255 
种 颜色 ， 计 算 新 的 被 重新 采样 的 像素 及 其 颜色 时 采用 了 一 各 近似值。 尝试 为 调 ee 
磊 色 时 ， 如 果 失 败 那么 选择 计算 结果 最 接近 ( 理论 上 ) 的 颜色 ( 并 不 是 视觉 上 最 接近 的 闫 色 ) 。 
可 能 会 产生 怪异 的 结果 ， 例 如 空白 (或 者 视觉 上 是 空白 ) 的 图 像 。 要 解决 这 个 问题 ， 人 有 
图 像 作为 目标 图 像 ， 例 如 使 用 imagecreatetruecolor0 函 数 创建 的 图 像 。 


图 设计 过 程 

(1) 创建 一 个 图 片上 传 功能 ， 将 图 片上 传 到 服务 器 指定 的 文件 夹 下 ， 并 通过 文件 系统 函数 读 取 存 储 在 指定 
目录 下 的 图 片 。 

(2) 在 图 片 输出 的 同时 ， 在 右 侧 创建 一 个 表单 ， 提 交 图 片 的 存储 位 置 、 名 称 和 要 调整 的 尺寸 ， 将 数据 提交 
到 index_ok.php 文件 中 。 

(3) 创建 index_ok.php 文件 ， 包 含 humbnail.php 文件 ， 实 例 化 image 类， 调用 其 中 的 thumb0 方 法 ， 以 表 
单 中 提交 的 数据 作为 参数 ， 完 成 对 图 片 大 小 的 调整 ， 其 关键 代码 如 下 : 


<?php 
这 $_POST['Submit] 一 "调整 图 像 大 小 "){ 
include("thumbnail.php"); // 包 含 图 像 类 存储 文件 
Simg = new imageO: 1/ 实例 化 图 像 处 理 类 
Sreturn=$img->param($ POST[pic path'"])->thumb("./thumbnail/".$ POST[pic name']. $ POST[pic width'1.$ POST["pic height",1); 
echo "<script>alert( 图 像 大 小 设置 成 功 ! ): window.location href-'index.php':</script>": 
} 
> 
(4) 创建 thumbnailphp 文件 ， 编 写 image 类 ， 定 义 thumb0 方 法 ， 根 据 表单 中 提交 的 数据 ， 完 成 图 像 大 小 
的 调整 操作 。 其 关键 代码 如 下 : 
//thumb( 新 图 地 址 . 宽 . 高 , 裁剪， 人 允许 放大 ) 
public function thumb($filename. $news_w = 100. Snews h = 100. $cut= 0. $big =0) { 
Sinfo = $this->getImageInfo ( $this->img ); /获取 原 图 信息 
if(! empty ( Sinfo [0] )) { 

S$old_w = $info [0]: 

S$old h= $info [1]: 

Snew w= $old w+ Snews Ww: 

Snew h = $old h+ Snews h: 

Stype = $info ['type'l:; 

Sext = Sinfo [ext]: 

unset ( Sinfo ); 
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if($old w < Snew h && $old h< $new w && ! $big) { // 如 果 原 图 比 缩 略图 小 ， 并 且 不 允许 放大 
Tetum false; 

} 

if(Scut—1){ /居中 裁剪 


S$scalel = round ( Snew_w/Snew_ h.2): 
S$scale2 =round ( $old WwW/1Sold_h. 2); 
证 (Sscalel > $scale?) { 
Send h=round ( $old w/ $scalel, 2); 
Sstart h= (S$old h- $end h) /2; 


Send w=round ($old h* $scalel, 2); 
Sstart_ w= (Sold_w ~ Send_w) /2; 


Swidth = Snew_w; // 定 义 图 像 宽 
Sheight = $new_h; // 定 义 图 像 高 


S$createFun = TImageCreateFrom' . $type; /新 建 图 像 
Soldimg = $createFun ( $this->img ); 
2 ‘gif &é& function exists ( "imagecreatetruecolor )) { 
= imagecreatetruecolor ( $width, $height ); // 创 建新 的 真 彩 图 像 
} else 
Snewimg = imagecreate ( $width, Sheight ); // 创 建新 的 图 像 


} 
if (function exists ( "ImageCopyResampled" )) { 
ImageCopyResampled ( Snewimg, $oldimg, 0, 0, $start_w, $start_h, $width, $height, $end_w, $end_h ); // 完 成 图 像 的 复制 
}else{ 
ImageCopyResized ( $newimg, $oldimg, 0. 0, $start w, $start h, $width, Sheight, Send w, Send h); 
} 


Stype 一 jpeg &é imageinterlace ( Snewimg 1 ); // 对 .jpeg 图 形 设置 隔行 扫描 
="image’ . $type; // 生 成 图 片 

! @$imageFun ( Snewimg, $filename ) && die ( ' 保 存 失 败 ! ); 

ImageDestroy ( $newimg ); /销毁 图 像 

Teturn $filename; /返回 图 像 名 称 


} 


力 秘笈 心 法 


心 法 领悟 285: 自制 图 像 处 理工 具 。 

在 本 实例 中 我 们 编写 的 只 是 一 个 可 以 按 比 例 任意 调整 图 像 大 小 的 方法 ， 如 果 读 者 感 兴趣 可 以 对 这 个 方法 进 
行 扩展 ， 例 如 ， 向 图 像 中 添加 水 印 、 以 数值 的 形式 调整 图 像 大 小 、 向 图 像 中 添加 文字 以 及 给 图 像 生 成 缩 略 图 等 
如 果 将 这 些 功能 综合 到 一 起 ， 那 么 它 就 变 成 了 一 个 简单 、 实 用 的 图 像 处 理工 具 了 。 本 实例 虽然 没有 将 这 些 功能 
进行 整合 ， 但 是 这 里 提 到 的 每 种 方法 ， 在 我 们 的 实例 中 都 有 体现 ， 读 者 可 以 尝试 自己 将 它们 整合 到 一 起 。 


实例 286 


力 实例 说 明 

网 站 的 图 片 被 盗 链 ， 是 一 件 让 人 非常 郁闷 的 事情 。 盗 链 不 仅 盗用 图 片 ， 更 直接 的 问题 是 用 户 在 下 载 盗 链 人 
网 站 上 的 图 片 时 ， 会 给 服务 器 带 来 压力 ， 导 致 日 志 中 的 访问 记录 暴涨 ， 而 带宽 被 耗 尽 。 为 了 打击 次 链 行为 ， 本 
节 介 绍 一 种 方法 ， 让 盗 链 者 的 某 些小 伎俩 不 能 得 偿 一 APACHE 防盗 技术 。 

对 APACHE 服务 器 进行 设置 后 ， 当 盗 链 者 盗 链 网 站 的 图 片 时 ， 将 输出 如 图 6.17 所 示 的 效果 。 


383 
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6.17 被 盗 链 图 片 和 盗 链 后 的 输出 结果 


力 关键 技术 


要 防止 网 站 图 片 被 盗 链 ， 就 有 必要 先 了 解 盗 链 的 手段 ， 基 本 可 以 分 为 以 下 两 种 : 
回 “” 盗 链 者 直接 使 用 图 片 链接 引用 网 站 上 的 图 片 。 
这 种 方式 就 是 我 们 在 实例 说 明 中 叙述 的 那 种 情况 ， 这 种 盗 链 行为 是 可 以 完全 防止 的 。 
防止 这 种 盗 链 情 况 的 发 生 ， 有 两 种 可 行 的 方法 : 通过 Apache 服务 器 进行 控制 和 使 用 SESSION 变量 在 程序 
中 进行 控制 。 
盗 链 者 直接 从 网 站 上 下 载 图 片 并 且 复 制 使 用 。 
这 种 方式 不 可 能 被 真正 地 阻止 ， 我 们 能 做 的 只 是 让 它 的 下 载 更 加 困难 而 已 。 防 止 的 方法 有 屏蔽 页 面 中 的 右 
键 使 用 功能 、 禁 止 对 网 页 的 下 载 等 。 
Apache 防盗 技术 的 原理 与 PHP 伪 静 态 技术 的 原理 是 相同 的 ， 都 需要 应 用 Apache 的 mod_rewrite.so 模 组 。 
Apache 服务 器 的 配置 文件 httpd.conf 的 修改 方法 如 下 : 
(1) 打开 httpd.conf 文件 ， 定 位 到 如 下 位 置 : 
机 oadModule rewrite module modules/mod rewrite so 
将 该 项 前 面 的 “# ”去 掉 ， 并 启动 该 项 。 
(2) 查找 httpd.conf 文件 ， 找 到 其 中 的 AllowOverride 项 ， 将 它 的 值 都 修改 为 All。 保 存 并 重新 启动 Apache 
服务 器 ， 使 修改 生效 。 
(3) 在 实例 根 目录 下 创建 .htaccess 文件 ， 定 义 防 止 网 站 图 片 被 盗 链 的 方法 。.htaccess 文件 的 代码 如 下 : 
SetEnvIfNoCase Referer "whttp:/192.168.1.59/" local_ ref-1 
<FilesMatch ".(gifljpg)"> 
Order Allow.Deny 


Allow from env=local ref 
</FilesMatch> 
Referer 字段 : 当 Apache 处 理 一 个 请 求 时 , 将 检测 头 信 息 里 的 Referer 字段 , 并 且 设 置 环境 变量 local ref 
为 1， 如 果 请 求 从 本 身 的 网 站 地 址 开始 ， 即 是 本 网 站 的 一 个 页 面 。 
回 。 ^http:/192.168.1.59/: 是 一 个 正则 表达 式 ， 为 了 设置 环境 变量 ，Referer 值 必须 与 其 匹配 。 
"NoCase" 指 令 : 定义 正则 表达 式 的 值 ， 忽 略 字符 串 的 大 小 写 。 
Order Allow,Deny: 设置 Apache 对 当前 的 请 求 ， 将 执行 列表 中 的 Allow 指令 ， 然 后 重复 进行 Deny 
指令 。 
回 ”local ref: 设置 了 local ref 环境 变量 (无 论 什么 值 ) 的 请 求 ， 而 任何 其 他 的 请 求 将 被 拒绝 ， 因 为 它们 
不 符合 Allow 的 条 件 并 且 默 认 是 拒绝 访问 的 。 
这 就 是 通过 Apache 服务 器 来 防止 图 片 被 盗 链 的 方法 。 有 关 通 过 SESSION 变量 防止 图 片 被 盗 链 的 方法 将 在 
实例 287 中 进行 讲解 。 
图 设计 过 程 
这 里 沿用 实例 285 的 内 容 ， 并 在 其 基础 上 演示 如 何 通过 Apache 防止 网 站 图 片 被 盗 链 。 


(1) 修改 Apache 服务 器 的 配置 文件 httpd.conf， 具 体 步骤 请 参考 关键 技术 。 
(2) 在 实例 根 目录 下 创建 .htaccess 文件 ， 编 写 通过 Apache 服务 器 防止 图 片 被 盗 链 的 方法 ， 有 具体 代码 请 参 
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考 关键 技术 。 
(3) 在 另外 一 个 Apache 服务 器 上 重新 创建 一 个 程序 ， 在 程序 中 盗 链 本 实例 中 的 一 个 图 片 时 ， 将 出 现实 例 
说 明 中 所 示 的 运行 结果 。 
力 秘笈 心 法 
心 法 领悟 286， 在 Apache 服务 器 的 httpd.conf 文件 中 定义 防止 图 片 被 次 链 的 方法 。 
在 本 实例 中 ， 防 止 图 片 被 盗 链 的 方法 只 对 本 实例 中 的 图 片 有 效 ， 如 果 将 htacecess 文件 中 的 方法 定义 到 
httpd conf 中 ， 那 么 这 个 方法 将 对 本 服务 器 下 的 所 有 程序 都 有 效 。 
中 级 | 
趣味 指数 : 人 容 食 全 而 


ee oe | 
图 实例 说 明 由 


本 实例 将 介绍 另外 一 种 网 站 图 片 防盗 链 方 法 , 即 在 程序 中 通过 SESSION 
变量 防止 图 片 被 资 链 。 当 网 站 中 应 用 了 SESSION 防盗 链 技术 后 ， 如 果 网 站 
的 图 片 被 次 链 ， 将 输出 如 图 6.18 所 示 的 效果 。 

关键 技术 图 6.18 盗 链 后 的 输出 结果 

通过 SESSION 防盗 链 与 通过 SESSION 屏蔽 页 面 刷 新 对 计数 器 的 影响 原理 相同 。 在 页 面 中 ， 首 先 初始 化 
SESSION 变量 ， 定 义 一 个 SESSION 变量 并 赋值 为 TRUE。 然 后 ， 在 插入 图 像 的 <img> 标 答 中 ， 定 义 src 属性 的 
值 时 ， 不 直接 定义 指定 图 片 的 位 置 ， 而 是 链接 到 指定 的 .php 文件 中 ， 并 且 将 要 插入 的 图 像 名 称 作为 超 链 接 的 参 
数值 传递 到 .php 文件 中 。 最 后 ,在 .php 文件 中 ， 通 过 判断 SESSION 变量 的 值 是 否 为 真 ， 决 定 超 链接 中 传递 的 图 
片 是 否 被 输出 ， 而 完成 对 网 页 中 图 片 的 保护 。 


图 设计 过 程 
(1) 设计 一 个 简单 的 网 页 。 首先， 在 这 个 页 面 中 初始 化 一 个 SESSION 变量 ， 并 且 设置 变量 的 值 为 TRUE。 
然后 ， 在 <img> 标 签 中 ， 将 src 的 属性 值 指定 到 getimage.php 文件 中 ， 并 且 将 插入 的 图 像 名 称 设置 为 超 链接 的 参 


数值 ， 其 关键 代码 如 下 : 
<?php 
session_start0: /初始 化 SESSION 变量 
$_SESSION['viewimages']=true: /定义 SESSION 变量 ， 并 为 其 赋值 
> 
<tr> 
<td colspan="2"> 


<img sre="getimage.php?img=bg3 01.jpg" width="267" height="31" alt=""></td> 
<img src="getimage php?img=bg3_02.jpe” width="536" height="31" alt=""></td> 


</t> 
(2) 创建 getimage.php 文件 ， 在 该 文件 中 通过 对 SESSION 变量 值 的 判断 ， 决 定 是 否 输出 图 像 ， 其 关键 代 

码 如 下 : 

<?php 

session_start0: / 补 始 化 SESSION 变量 

让 (isset($_SESSION[viewimages]) &c&c $ SESSION[viewimages] 一 tme) { ”// 判 断 SESSION 变量 是 否 为 真 

if (isset ($_GET [img] ) { // 超 链接 传递 的 值 是 否 存 在 

Sdims = getimagesize ('images/ . $_GET [img] ): /获取 超 链接 传递 图 片 的 信息 


header ( 'Content-Disposition: inline: filename=' .S GET [img]): 
header ('Content-Type: . $dims [mime'] ); 
header ( 'Content-Length:'. filesize (images/ . S_GET [img] ) ): 
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readfile ( "images/ . $_GET [img]): // 完 成 对 图 片 的 读 取 操 作 
} else { 
header ( "HTTP/1.1 404 NOT Found" ): 
header ( "Content-Type: text/plain" ); 
echo "图 像 不 存在 ! \n"; 
} 
}elsef 
header ("HTTP/1.1 404 NOT Found" ): 
header ( "Content-Type: text/plain" ); 
echo "这 是 一 个 被 保护 的 图 像 不 可 盗 链 ! \n"; 
} 


图 秘笈 心 法 

心 法 领悟 287: 防止 图 片 被 资 链 方法 的 选择 。 

通过 SESSION 变量 防盗 链 相对 通过 Apache 防盗 链 来 说 麻烦 一 些 ， 但 是 如 果 要 在 购买 的 虚拟 主机 中 使 用 ， 
那么 必须 考虑 虚拟 主机 的 Apache 配置 是 否 支持 mod_rewrite.so 模 组 。 而 使 用 SESSION 变量 来 防止 图 片 被 盗 链 ， 
则 不 必 考 虑 这 个 问题 ， 因 为 它 完 全 是 在 用 户 的 程序 中 运行 。 所 以 ， 具 体 使 用 哪 种 方法 来 防止 网 站 图 片 被 盗 链 ， 
可 以 根据 实际 情况 而 定 。 


6.3 Jpgraph 类 库 
Jpgraph 是 基于 GD2 函数 库 编写 的 主要 用 于 创建 统计 图 的 类 库 。 在 绘制 统计 图 方面 不 仅 功能 非常 强大 ， 而 


且 代码 编写 方便 ， 只 需 简单 的 几 行 代码 就 可 以 绘制 出 非常 复杂 的 统计 图 效果 ， 从 而 很 大 程度 地 提高 了 编程 人 员 
的 开发 效率 。 在 本 节 中 ， 将 通过 设计 各 种 类 型 的 统计 图 ， 让 大 家 全 面 地 体会 了 pgraph 类 库 的 强大 功能 。 
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实例 说 明 


在 本 实例 中 , 将 介绍 如 何 通过 Jpgraph 类 库 创 建 柱 形 图 ,完成 对 产品 月 销售 量 的 统计 分 析 ， 其 运行 效果 如 
图 6.19 所 示 。 


吉林 省 明日 科技 有 限 公司 6 月 份 纺 程 沿 典 销售 量 分 析 
人 ED 
EE 
00.0 
| | | | 
oe w we ne Apae 地 站 


6.19 柱 形 图 分 析 产 品 月 销售 量 


图 关键 技术 


要 运用 Jpgraph 类 库 ， 首 先 必须 了 解 它 如 何 下 载 、 都 有 哪些 版 本 、 都 适用 于 哪些 环境 。Jpgraph 包括 人 pGraph 
1x 系列 、JpGraph 2.x 系列 和 JpGraph 3.x 系列 。 
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JpGraph 1.x 系列 仅 适 用 于 PHP 4 环境，PHP5 下 不 能 工作 。 


JpGraph 2.x 系列 仅 适 用 于 PHP 5 环境 (三 5.1.x)，PHP 4 下 不 能 工作 。 目前 2.x 系列 的 最 新 版 本 是 2.3.4。 


JpGraph 3X 系列 是 2.x 的 升级 版 本 ， 目 前 最 新 的 版 本 是 3.0.6。 
本 书 中 应 用 的 是 最 新 版 本 JpGraph 3.0.6。 


配置 Jpgraph 的 最 简单 的 方法 就 是 将 解压 后 的 src 文件 夹 直 接 复制 到 范例 的 根 目录 下 。 这 样 就 可 以 直接 在 程 


序 中 调用 src 文件 夹 下 的 文件 ， 应 用 Jpgraph 类 库 绘制 统计 图 。 


图 设计 过 程 


(1) 将 Jpgraph 类 库 导入 到 程序 中 。 


使 用 了 pgraph 类 库 , 首先 要 从 网 站 http://www.aditus.nu/ipgraph/ 下 载 该 类 库 的 压缩 包 并 解压 , 将 呈现 如 图 6.20 


所 示 的 目录 结构 。 
Docs 一 有 文本 
Bc 一 一 一 一 一 一 一 一 一 一 二 文件 
上 orm 《一 Ww 
四 no 一 一 一 一 一 一 一 一 一 一 一 ”六 文 人 8 
国 versIon 版 本 声明 


图 6.20 Jpgraph 压缩 包 解压 后 的 目录 
(2) 将 src 文件 夹 复制 到 实例 的 根 目 录 下 。 


(3) 创建 index.php 文件 ， 将 Jpgraph 导入 到 项 目 中 ， 上 有 具体 操作 步骤 如 下 : 


使 用 Graph 类 创建 统计 图 对 象 ; 
调用 Graph 类 的 SetScale0 方 法 设置 统计 图 的 刻度 样式 ; 
调用 Graph 类 的 SetShadow0 方 法 设置 统计 图 阴影 ; 


调用 BarPlot 类 创建 统计 图 的 柱 形 效果 ; 

调用 BarPlot 类 的 SetFillColor0 方 法 设置 柱 形 图 的 前 景色 。 
index.php 的 关键 代码 如 下 : 

<?pl 


?php 
header ( "Content-type: texthtml: charset=UTF-8" ); 
require_once 'sre/ipgraph.php’; 
require_once 'sre/jpgraph_bar.php'; 
$data = array(80, 73, 89, 85. 92); 
Sdatas = array("C#", "VB", "VC", "JAVA", "ASP.NET"): 
Sgraph = new Graph(600, 300); 
Sgraph->SetScale('textlin): 
Sgraph->SetShadowO; 
Sgraph->img->SetMargin(40, 30, 20, 40); 
S$barplot = new BarPlot($data): 
S$barplot->SetFillColor('blue’): 
$barplot->value->ShowO; 
Sgraph->Add($barplot): 


因 办 办 办 办 办 


Sgraph->title->Set(iconv("utf-8","gb2312"," 吉 林 省 明日 科技 有 限 公 司 6 月 份 编程 词典 销售 量 分 析 ")); 


S$eraph->xaxis->title->Set(iconv("utf-8","gb2312"," 部 门 ")); 
Sgraph->xaxis->SetTickLabels($datas): 
$egraph->yaxis->title->Set(iconv("utf-8"."gb2312",' 总 数量 (本 ))); 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): 
Sgraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD): 
Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD): 
Seraph->Stroke0: 
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调用 Graph 类 的 img 属性 的 SetMargin() 方 法 设置 统计 图 的 边界 范围 ， 


/设置 文件 编码 格式 
/导入 Jpgraph 类 库 

// 导 入 Jpgraph 类 库 的 柱 形 图 功能 
/设置 统计 数据 
/设置 统计 数据 
/设置 画布 大 小 
/设置 坐标 刻度 类 型 
/设置 画布 阴影 
/设置 统计 图 边 距 

1/ 实例 化 BarPlat 对 象 
/设置 柱 形 图 前 景色 


/统计 图 标题 
/设置 和 X 轴 名 称 


/设置 Y 轴 名 称 
/设置 标题 字体 
/设置 入 轴 字体 
/设置 Y 轴 字体 
/输出 图 像 
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如 果 想 要 Jpgraph 在 Apache 服务 器 下 的 所 有 站 点 均 有 效 ， 可 以 按 如 下 步骤 进行 配置 : 
(1) 将 解压 后 的 sre 文件 夹 保存 到 服务 器 磁盘 中 ， 例 如 cypgraph。 
(2) 编辑 php.ini 文件 , 修改 include_path 的 配置 项 ,在 该 项 后 增加 pgraph 类 库 的 保存 目录 , 例如 include_ 
path = “.;c:\jpgraph”。 
(3) 重新 启动 Apache 服务 ， 配 置 生效 。 
这 样 pgraph 就 在 Apache 服务 器 下 的 所 有 站 点 中 都 有 效 了 。 


收 支 情况 高 级 
趣味 指数 : 二 
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图 实例 说 明 _ 
在 本 实例 中 ， 运 用 Jpgraph 生成 柱 形 图 ， 对 公司 年 度 总 的 收 支 情况 进行 分 析 ， 其 运行 结果 如 图 6.21 所 示 。 


Ee 98.0 
EF 
64.0 5.0 
79.0 
75.0 
| i | | | | | 
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图 6.21 公司 年 度 收 支 展示 


力 关键 技术 


在 本 实例 中 以 年 为 单位 ， 分 析 在 一 年 中 公司 每 个 月 的 收 支 情况 。 首 先 ， 确 立 一 年 中 每 个 月 的 业绩 。 然 后 ， 
确定 柱 形 图 的 标题 、X 轴 、Y 轴 显 示 的 内 容 。 最 后 ， 将 src/jpgraph.php 导入 到 项 目 中 ， 完 成 柱 形 图 的 创建 ， 其 
具体 方法 解析 如 下 : 

(1) 通过 include0 语 句 包 含 创建 指定 图 像 所 需 的 文件 。 在 本 实例 中 创建 柱 形 图 ， 需 要 使 用 的 文件 如 下 : 

Tequire_once '../src/jpgraph.php': // 导 入 Jpgraph 类 库 

require_once ,src/jpgraph_barphp' /导入 Jpgraph 类 库 的 柱 形 图 功能 

(2) 使 用 Graph 类 创建 统计 图 对 象 。 

使 用 Jpgraph 类 库 首 先 需要 创建 统计 图 对 象 ， 统 计 图 对 象 使 用 Graph 类 创建 ， 该 类 的 使 用 语法 如 下 : 

Seraph = new Graph(Sw. Sh); 

参数 说 明 : 

$w: 指定 图 片 的 宽度 。 

$h: 指定 图 片 的 高 度 。 

(3) 调用 Graph 类 的 SetScale0 方 法 设置 统计 图 的 刻度 样式 。 

统计 图 的 X 轴 有 和 立轴 的 样式 有 多 种 , 可 以 使 用 Graph 类 的 SetScale0 方 法 设置 统计 图 刻度 的 样式 , SetScale0 
方法 的 语法 如 下 : 

Seraph->SetScale(Stype) 

$type: 表示 XX 轴 样 式 和 YY 轴 样 式 的 组 合 ， 具 体 组 合 方式 如 表 6.2 所 示 。 
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表 6.2 SetScale( 方 法 X 轴 与 Y 轴 样 式 说 明 


例如 ，textlog 表示 义 轴 坐标 为 文本 样式 ，Y 轴 为 对 数 样式 的 X-Y 刻度 。 
(4) 调用 Graph 类 的 SetShadow0 方 法 设置 统计 图 阴影 。 
默认 情况 ， 应 用 Jpgraph 绘制 出 统计 图 的 下 边框 和 右边 框 是 没有 阴影 效果 的 ， 使 用 Graph 类 的 SetShadow() 


Seraph->SetShadowO 


方法 可 以 为 统计 图 添加 阴影 效果 ， 从 而 使 统计 图 具有 立体 感 。SetShadow0 方 法 的 语法 如 下 : 


(5) 调用 Graph 类 的 img 属性 的 SetMargin0 方 法 设置 统计 图 的 边界 范围 。 
使 用 SetMargin() 方 法 可 以 为 统计 图 设置 边界 范围 ， 使 统计 图 制作 变 得 更 为 灵活 ， 该 方法 的 语法 如 下 : 


Seraph->img->SetMargin(Sleft Sright $up, $bottom) 
参数 说 明 : 

$left: 统计 图 左边 距 。 

S$right: 统计 图 右边 距 。 

$up: 统计 图 上 边 距 。 

$bottom: 统计 图 下 边 距 。 

(6) BarPlot 类 创建 统计 图 的 柱 形 效果 。 


使 用 Jpgraph 创建 柱 形 图 需要 使 用 BarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数值 数组 参数 ， 该 数组 的 内 容 即 


为 需要 统计 的 数据 。BarPlot 类 的 语法 如 下 : 


$barPlot = new BarPlot($data) 


$data: 由 统计 数据 所 组 成 的 数组 。 


(7) 调用 BarPlot 类 的 SetFillColor0 方 法 设置 柱 形 图 的 前 景色 。SetFillColor0 方 法 的 语法 如 下 : 


$barplot->SetFillColor($color); 


$color: 要 设置 的 颜色 值 。 
设计 过 程 


(1) 创建 index.php 文件 ， 设 置 页 面 的 编码 格式 ， 将 sre 文件 夹 导入 到 实例 根 目录 下 。 


header ( "Content-type: text/html; charset=UTF-8" ); 
Tequire_once '../sre/ipgraph.php'; 
Tequire_once '../src/jpgraph_bar.php'; 
(2) 应 用 Jpgraph 类 库 中 的 方法 完成 柱 形 图 的 创建 ， 
<Iphp 


header ( "Content-type: text/html; charset=UTF-8" ); 
Tequire_once 'sre/jpgraph.php'; 

Tequire_once 'sre/ipgraph_bar.php'; 

$data = array(80, 73, 89, 85, 92, 75 .85 .65. 84. 79. 85. 98); 

Sgraph = new Graph(600, 300): 

Sgraph->SetScale('textlin); 

Sgraph->SetShadowO; 

$egraph->img->SetMargin(40. 30. 20. 40): 

Sbarmplot = new BarPlot(Sdata): 

Sbarplot->SetFillColor('blue’); 

$barplot->value->ShowO:; 

Sgraph->Add($barplot): 
$eraph->title->Set(iconv("utf-8","gb2312",' 公 司 2009 年 度 收 支 ); 
Sgraph->xaxis->title->Set(iconv("utf-8"."gb2312",' 月 份 )); 
Sgraph->yaxis->title->Set(iconv("utf-8","gb2312", 总 金额 (万 元 )): 
S$eraph->title->SetFont(FF_SIMSUN, FS_BOLD): 
Seraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD): 


// 设 置 文件 编码 格式 
/导入 Jpgraph 类 库 
/导入 Jpgraph 类 库 的 柱 形 图 功能 


其 关键 代码 如 下 : 


/设置 文件 编码 格式 

/导入 Jpgraph 类 库 

// 导 入 Jpgraph 类 库 的 柱 形 图 功能 
// 设 置 统计 数据 

/设置 画布 大 小 

/设置 坐标 刻度 类 型 

/设置 画布 阴影 

// 设 置 统 计 图 边 距 

// 实 例 化 BarPlat 对 象 

// 设 置 柱 形 图 前 景色 


// 设 置 统计 图 标题 
/设置 入 轴 名 称 
/设置 立轴 名 称 
// 设 置 标题 字体 
/设置 和 X 轴 字体 
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Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD): /设置 立轴 字体 
$eraph->Stroke(); /| 输出 图 像 
图 秘笈 心 法 


心 法 领悟 289: 转换 编码 格式 的 重要 性 。 
由 于 本 实例 采用 的 是 utf-8 编码 ， 所 以 在 生成 的 图 像 中 输出 中 文字 符 串 时 ， 必 须 对 其 进行 编码 转换 ， 同 时 要 


设置 字体 为 SetFont(FF_SIMSUN,FS_BOLD)， 如 果 使 用 其 他 类 型 的 字体 ， 即 使 完成 编码 转换 ， 输 出 的 中 文字 符 
串 仍然 是 乱码 。 
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趣味 指数 : 从 信众 雯 从 


图 实例 说 明 


在 本 实例 中 , 运用 Jpgraph 生成 对 比 柱 形 图 , 对 编程 词典 6、7 月 份 的 销售 量 进行 比较 , 其 运行 结果 如 图 6.22 


所 示 。 
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图 6.22 编程 词典 6、7 月 份 销量 对 比 


图 关键 技术 


在 本 实例 中 通过 柱 形 图 完成 对 编程 词典 6、7 月 份 销量 的 对 比 ,此 例 在 单一 柱 形 图 的 基础 上 增加 一 组 柱 形 图 ， 
形成 两 组 数据 的 对 比 效果 ， 其 实现 方法 与 单一 柱 形 图 是 相同 的 ， 可 以 说 是 创建 两 个 单一 的 柱 形 图 ， 然 后 将 其 在 
同一 图 像 中 输出 。 

(1) 通过 BarPlot 类 创建 柱 形 图 , 运用 其 返回 对 象 调用 value0 方 法 中 的 Show0 方 法 输出 数据 , 通过 SetColor0 
方法 设置 输出 数据 颜色 。 

SetColor0 方 法 的 语法 如 下 : 


SetColor(SaColor, SaLabelColor) 

参数 说 明 : 

$aColor: 设置 坐标 轴 的 颜色 ; 

$aLabelColor: 设置 坐标 轴 上 标签 的 颜色 ， 默 认 值 为 false。 

(2) 通过 Add(0 方 法 将 柱 形 图 数据 添加 到 图 像 中 ， 其 参数 是 柱 形 图 创建 返回 的 对 象 ， 语 法 如 下 : 

en 

$aPlot: 指定 图 像 创建 时 返回 的 对 象 。 

(3) 在 本 实例 中 ,还 应 用 到 GroupBarPlot 类 创建 柱 形 图 数组 ， 通 过 该 类 可 以 实现 对 柱 形 图 的 分 段 处 理 ， 如 
果 重 新 设置 数组 $datazero 的 值 ， 那 么 柱 形 图 会 发 生 一 些 变化 。 


Class GroupBarPlot Extends BarPlot 
GroupBarPlot :: 
GroupBarPlot($plots) 
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GroupBarPlot 创建 一 个 新 的 图 像 对 象 ，$plots 是 一 个 数组 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 


(2) 应 用 了 pgraph 类 库 中 的 方法 完成 对 比 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 


<2php 
header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/ipgraph php"); 
include ("../src/jpgraph_bar.php"); 
Sdata july = array(90, 63, 69, 105, 92); 
Sdata_june = array(180, 173, 189, 145, 202); 
$datazero=array(0,0,0,0,0); 
Sdatas = array("C#", "VB", "VC", "JAVA", "ASP.NET"); 
Seraph = new Graph(600,270); 
Seraph->SetScale("textlin"); 
$eraph->SetY2Scale("lin"): 
Sgraph->img->SetMargin(50, 40, 20, 40); 
Seraph->yaxis->scale->SetGrace(20); 
Seraph->y2axis->scale->SetGrace(20); 
Sgraph->SetMarginColor('white’); 
Sgraph->y2axis->SetColor('darkred"); 
$bplotzero = new BarPlot($datazero); 
Sybplotl = new BarPlot($data_july); 
S$ybplotl->value->ShowO; 
S$ybplot = new GroupBarPlot(array($ybplot1.,$bplotzero)): 
S$ybplot2 = new BarPlot(Sdata_ june); 
S$ybplot2->value->ShowO; 
Sybplot2->value->SetColor('darkred); 
S$ybplot2->SetFillColor('darkred"); 

$y2bplot = new GroupBarPlot(array($bplotzero, Sybplot2)); 
// 将 数据 添加 到 图 像 中 
Sgraph->Add($ybplot); 
Sgraph->AddY2($y2bplot); 


$egraph->title->Set(iconv("utf-8","gb2312", 编 程 词典 2009 年 6、7 月 份 销售 对 比 ); 


S$graph->xaxis->title->Set(iconv("utf-8","gb2312"'6、7 月 份 ); 
Segraph->xaxis->SetTickLabels($datas): 
Sgraph->yaxis->title->Set(iconv("utf-8","gb2312",' 总 金额 (万 元 ))); 
Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD): 
Sgraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD); 
Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD); 
Sgraph->Stroke():; 

?> 


图 秘笈 心 法 
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性 。 


/设置 文件 编码 格式 
/1/ 导 入 文件 

/导入 文件 

/设置 统计 数据 
/设置 统计 数据 


/设置 统计 数据 
/创建 图 像 
/设置 坐标 刻度 类 型 


/设置 统计 图 边 距 


/创建 背景 颜色 


/设置 图 像 的 填充 值 
/创建 6 月 份 数 据 


/创建 7 月 份 数 据 
/输出 数据 


// 设 置 统计 图 标题 
/设置 入 轴 名 称 


/设置 站 轴 名 称 
/设置 标题 字体 
/设置 X 轴 字体 
// 设 置 Y 轴 字体 
/生成 图 像 


在 通过 Jpgraph 类 库 创建 图 像 时 , 要 想 在 图 像 中 输出 中 文字 符 串 ,只 对 字符 串 的 编码 格式 进行 转换 是 不 够 的 ， 
还 要 为 中 文字 符 串 设 置 正确 的 字体 (SetFont(FF_SIMSUN, FS_ BOLD)) ， 否 则 无 论 怎 么 转换 字符 串 的 编码 格式 
都 是 徒劳 的 。 
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力 实例 说 明 


在 本 实例 中 ,运用 Jpgraph 生成 柱 形 图 ， 对 公 


司 编程 词典 上 半年 的 销量 进行 统计 ， 其 运行 结 


果 如 图 6.23 所 示 。 
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从 程 词 江 上 半年 总 的 稍 告 量 分 析 


人 


图 6.23 编程 词典 上 半年 销量 展示 


图 关键 技术 


在 本 实例 中 ， 对 编程 词典 上 半年 的 销量 进行 分 析 ， 这 里 创建 的 柱 形 图 与 上 面 实例 创建 的 柱 形 图 的 唯一 区 别 
是 形状 和 颜色 不 同 。 

本 实例 通过 BarPlot 类 中 的 SetFillGradient(0 方 法 完成 对 柱 形 图 颜色 和 形状 的 设置 ， 其 语法 如 下 : 

SetFillGradient($aFromColor, $aToColor, $aStyle) 

参数 说 明 : 

$aFromColor: 默认 颜色 ， 

$aToColor: 转换 的 颜色 ; 

$aStyle: 设置 的 样式 。 

本 实例 中 的 具体 应 用 如 下 : 


SetFillGradient ("navy","#FFFF00",GRAD_LEFT_REFLECTION); // 设 置 图 像 的 类 型 和 填充 颜色 


设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 
Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 完成 特殊 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 
Ee "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 


include ("../src/ipgraph.php"): 

include (". /src/jpgraph_bar. php"); 

Sdatay=array(150,201,145,340,265.365); 
y("Jan","Feb", "Mar","Apr","May","June"); 


Sgraph = new Graph(400,200,"auto"); // 创 建 图 像 
Seraph->img->SetMargin(60,20.30,50); // 设 置 图 像 边 框 间 距 
Sgraph->SetScale("textlin"); /定义 坐标 刻度 类 型 
$egraph->SetMarginColor("lightblue”): /定义 图 像 颜色 
Sgraph->title->Set(iconv("utf-8","gb2312", 编 程 词典 上 半年 总 的 销售 量 分 析 )); // 定 义 标题 
$egraph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
$eraph->xaxis->SetFont(FF_VERDANA,FS_ NORMAL.10): /设置 入 轴 的 字体 
Seraph->yaxis->SetFont(FF_VERDANA,FS_NORMAL.10); /设置 丫 轴 的 字体 
$egraph->xaxis->SetTickLabels($datax): // 设 置 X 轴 输出 的 数据 
Sgraph->xaxis->SetLabelAngle(50): /设置 输出 文字 大 小 
$bplot = new BarPlot(Sdatay): /实例 化 图 像 创 建 类 
$bplot->SetWidth(0.6): // 设 置 柱 形 图 的 输出 大 小 
$bplot->SetFillGradient("navy","#FFFF00",GRAD LEFT_ REFLECTION): // 设 置 图 像 的 类 型 和 填充 颜色 
S$bplot->SetColor("white”); /设置 图 像 边框 颜色 
Sgraph->Add($bplot): // 漆 加 数据 
Sgraph->StrokeO; /生成 图 像 
> 

图 秘笈 心 法 


心 法 领悟 291: SetFillGradient(0 方 法 的 妙用 。 
通过 SetFillGradient0 方 法 不 但 可 以 改变 柱 形 图 的 形状 ， 还 可 以 使 柱 形 图 变 得 更 加 光滑 ， 其 方法 如 下 : 


/Sbplot->SetFillGradient("navy"."lightsteelblue".GRAD MIDVER): 
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图 实例 说 明 


在 本 实例 中 ， 运 用 pgraph 生成 柱 形 图 ， 对 公司 年 度 总 的 收 支 情况 进行 分 析 ， 其 运行 结果 如 图 6.24 所 示 。 


公司 2009 年 上 半年 总 的 销售 额 
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图 6.24 公司 2009 年 上 半年 总 销售 额 


图 关键 技术 


在 本 实例 中 ， 通 过 柱 形 图 展示 公司 2009 年 上 半年 总 的 销售 额 ， 这 个 柱 形 图 的 特点 体现 在 背景 图 像 、X 轴 时 
间 、 数 据 输出 和 数据 的 格式 化 上 。 

(1) 通过 图 像 的 SetFrame0 方 法 控制 背景 图 像 ， 其 语法 如 下 : 

SetFrame($aDrawImgFrame, $almgFrameColor, $almgFrame Weight) 

参数 说 明 : 

$aDrawImgFrame: 如 果 将 该 参数 设置 为 FALSE， 那 么 就 不 输出 背景 图 像 ， 如 果 设 置 为 TRUE 或 者 不 应 用 
该 方法 那么 将 输出 背景 图 像 。 

$aImgFrameColor: 该 参数 是 一 个 数组 ， 定 义 背 景 图 像 的 颜色 。 

$aImgFrameWeight: 默认 值 为 1， 设置 背景 宽度 。 

(2) 和 轴 上 时 间 的 设置 。 大 家 可 以 看 到 ，X 轴 上 的 时 间 坐 标 采用 的 是 月 份 的 英文 简写 格式 ， 这 个 时 间 数 据 
不 是 通过 数组 定义 的 ， 而 是 应 用 GetShortMonth0 方 法 直接 生成 的 ， 其 代码 如 下 : 


$a = $gDateLocale->GetShortMonthO); /定义 义 轴 输出 的 内 容 ， 英 文 月 份 的 简写 
然后 通过 图 像 中 xaxis 对 象 中 的 SetTickLabels0 方 法 将 数据 添加 到 义 轴 上 ， 其 代码 如 下 : 
Segraph->xaxis->SetTickLabels(Sa): /添加 数据 


(3) 柱 形 图 中 数据 的 输出 ， 应 用 的 是 柱 形 图 value 对 象 中 的 Show0 方 法 ， 然 后 应 用 SetAngle0 方 法 设置 数 
据 的 输出 角度 ， 应 用 SetFormat0 方 法 对 数据 进行 格式 化 ， 其 关键 代码 如 下 : 


$bplot->value->ShowO; /输出 图 像 对 应 的 数据 值 
$bplot->value->SetAngle(45); // 定 义 图 像 值 的 输出 角度 
$bplot->value->SetFormat('$ %60.0f):; /1/ 对 输出 值 进行 格式 化 


(4) 调用 自 定义 函数 ， 对 数据 进行 格式 化 操作 。 本 实例 应 用 图 像 中 yaxis 对 象 中 的 SetLabelFormatCallbackO 


方法 调用 自 定义 函数 ， 执 行 数 据 的 格式 化 操作 ， 其 关键 代码 如 下 : 
$eraph->yaxis->SetLabelFormatCallback('yScaleCallback); /| 执行 数字 的 格式 化 输出 


其 中 yScaleCallback 为 自 定义 函数 的 名 称 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 
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Jpgraph 文件 。 


(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 没有 背景 图 像 的 柱 形 图 ， 其 关键 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/ipgraph.php"); 
include ("../src/ipgraph_bar.php"): 
function yScaleCallback($aVal) { 

Teturn number format($aVal): 
} 
S$datay=array(120567,134013,192000,87000.98000,45000); 
Sgraph = new Graph(650,280,'auto); 
Segraph->img->SetMargin(80.30.30.40); 
Seraph->SetScale("textint"); 
Seraph->SetShadowO; 
Sgraph->SetFrame(false); 
Seraph->yaxis->scale->SetGrace(35); 
Sgraph->yaxis->SetLabelFormatCallback('yScaleCallback); 
$a = $gDateLocale->GetShortMonth(); 
Sgraph->xaxis->SetTickLabels($a); 
Sgraph->xaxis->SetFont(FF_FONT2); 
$graph->title->Set(iconv("utf-8","gb2312", 公 司 2009 年 上 半年 总 的 销售 额 ); 
Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD): 
Seraph->xaxis->title->Set("Year 2009"); 
Seraph->xaxis->title->SetFont(FF_FONT2,FS_BOLD); 
Sbplot = new BarPlot($datay); 
$bplot->SetFillColor("orange"): 
S$bplot->SetWidth(0.5); 
$bplot->SetShadow(0): 
$bplot->value->ShowO:; 
$bplot->value->SetFont(FF_ARIAL.FS_BOLD); 
S$bplot->value->SetAngle(45); 
S$bplot->value->SetFormat('$ %%0.0f); 
S$bplot->value->SetColor("black","darkred"); 
Sgraph->Add($bplot); 
Sgraph->StrokeO; 
?> 


图 秘笈 心 法 


心 法 领悟 292: 通过 Jpgraph 创建 图 像 的 技巧 。 


在 通过 Jpgraph 类 库 创 建 图 像 时 ， 可 以 在 src\Examples 文件 夹 下 选择 你 想 要 创建 的 图 像样 式 ， 然 后 向 这 个 样 
式 中 添加 属于 自己 的 数据 ,如果 感觉 不 满意 ， 可 以 对 大 小 、 颜 色 等 进行 重新 调整 。 这 是 通过 Jpgraph 创建 图 像 最 


简单 、 最 直接 的 方法 。 


力 实例 说 明 


在 本 实例 中 ， 运 用 Jpgraph 生成 柱 形 图 ， 对 编程 词典 2009 年 第 一 季度 的 销量 情况 进行 分 析 ， 其 运行 


图 6.25 所 示 。 


键 技术 


在 本 实例 中 ,通过 多 柱 形 图 展示 2009 年 第 一 季度 编程 词典 的 销量 ,其 中 包括 C#、VB、VC、JAVA 和 ASP.NET5 


个 语言 编程 词典 的 销量 。 
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// 设 置 文 件 编码 格式 


/定义 数字 格式 化 的 方法 


/创建 图 像 
/定义 图 像 边 框 间距 
/定义 刻度 值 的 类 型 
/设置 图 像 阴影 

/不 设置 图 像 的 背景 

// 设 置 Y 轴 距离 顶部 的 距离 
/和 拱 行 数字 的 格式 化 输出 
/定义 义 轴 输出 的 内 容 ， 英 文 月 份 的 简写 
/| 添加 数据 

/设置 字体 

/定义 标题 

/设置 标题 字体 

/设置 入 轴 的 角 标 
/定义 字体 

// 创 建 图 像 
/定义 图 像 的 填充 颜色 

// 设 置 图 像 的 大 小 

// 设 置 图 像 的 阴影 
/输出 图 像 对 应 的 数据 值 
/定义 图 像 值 的 字体 
/定义 图 像 值 的 输出 角度 
/对 输出 值 进行 格式 
/定义 值 的 颜色 

// 添 加 数据 

// 生 成 图 像 


Eb 
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公司 2009 年 第 一 季 诺 沪 程 语 奥 销 售 情况 
190.0 


图 6.25 ”2009 年 第 一 季度 编程 词典 销量 展示 


本 实例 中 柱 形 图 创建 体现 的 是 多 柱 形 图 直接 对 比 输出 ， 其 关键 是 将 BarPlot 类 创建 的 单 柱 形 图 通过 
GroupBarPlot 类 整合 到 同一 个 图 像 中 进行 输出 。 

(1) BarPlot 类 创建 统计 图 的 柱 形 效果 。 

使 用 Jpgraph 创建 柱 形 图 需要 使 用 BarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数值 数组 参数 ， 该 数组 的 内 容 即 
为 需要 统计 的 数据 。BarPlot 类 的 使 用 格式 如 下 : 

SbarPlot = new BarPlot($data) 

参数 $data 由 统计 数据 所 组 成 的 数组 。 

(2) GroupBarPlot 类 创建 多 个 柱 形 效果 。 

使 用 Jpgraph 创建 多 个 柱 形 图 需要 使 用 GroupBarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数组 参数 ， 该 数组 的 
内 容 即 为 需要 整合 的 单个 柱 形 图 对 象 。GroupBarPlot 类 的 语法 如 下 : 


Sgbarplot= new GroupBarPlot ($data) 

参数 $data: 由 单个 柱 形 图 对 象 所 组 成 的 数组 。 

设计 过 程 

(1) 创建 ndex.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 
Jpgraph 文件 。 
(2) 应 用 pgraph 类 库 中 的 方法 创建 一 个 柱 形 图 数组 ， 对 2009 年 第 一 季度 编程 词典 销量 进行 分 析 ， 其 关键 
代码 如 下 : 

S$datay1=array(140.110.50.60.45): 

$datay2=array(35.90,190,80.120); 

$datay3=array(20.60.70,100.60): 

$egraph = new Graph(600,400); /创建 图 像 
Seraph->SetScale("textlin"); // 设 置 刻 度 值 类 型 
$graph->SetMargin(40.30.30.40); /定义 边框 距离 
$eraph->SetMarginColor('white:0.9); // 设 置 图 像 边 框 颜色 
$eraph->SetColor('white’); // 设 置 图 像 的 填充 颜色 
$datas = array("C#", "VB", "VC", "JAVA", "ASP.NET"): // 设 置 统 计数 据 
Sgraph->xaxis->SetTickLabels($datas): 

$eraph->xaxis->title->Set("Year 2009"); // 设 置 X 轴 标题 
Seraph->xaxis->title->SetFont(FF_FONTI1.FS_BOLD) : // 设 置 标题 字体 
$eraph->xaxis->title->SetColor('red); /设置 字体 颜色 
Sgraph->xaxis->SetFont(FF_FONTI1.FS_BOLD): // 设 置 多 轴 字 体 
S$eraph->xaxis->SetColor('navy’): /设置 X 轴 刻度 线 颜色 
Seraph->yaxis->SetFont(FF_FONTI1.FS_BOLD): /设置 立轴 字体 
Seraph->yaxis->SetColor('navy): /设置 Y 轴 刻度 线 颜色 
Sgraph->title->Set(iconv("utf-8"."gb2312", 公 司 2009 年 第 一 季度 编程 词典 销售 情况 ); /定义 标题 
Seraph->title->SetFont(FF_SIMSUN. FS_BOLD): /设置 标题 字体 
Seraph->title->SetMargin(3): // 设 置 图 像 距 离 顶 部 距离 
/创建 3 个 方 柱 统计 图 
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Sbplotl = new BarPlot($datay]); 
Sbplot = new BarPlot(Sdatay2); 
Sbplot3 = new BarPlot(Sdatay3); 


/省略 了 部 分 代码 

$bplot1->value->ShowO: /输出 图 像 对 应 的 数据 值 

$bplotl->value->SetFont(FF ARIALFS_BOLD): /定义 图 像 值 的 字体 

$bplot1->value->SetColor("black"."darkred"); /定义 值 的 颜色 

/省 略 了 部 分 代码 

/实例 化 图 像 操作 组 类 

Sgbarplot = new GroupBarPlot(array($bplot1,$bplot2,$bplot3)); 

S$gbarplot->SetWidth(0.8); /设置 图 像 大 小 

Sgraph->Add($gbarplot): // 淋 加 数据 

Seraph->Stroke0; /生成 图 像 
秘笈 心 法 


心 法 领悟 293: 图 像 颜 色 的 填充 。 
在 Jpgraph 类 库 中 ， 应 用 SetFillColor0 方 法 为 图 像 填 充 颜 色 ; 通过 SetColor( 方 法 定义 数据 、 文 字 、 坐 标 轴 
的 颜色 。 


内 的 访问 


ea 


走势 高 级 
趣味 指数 : 会 傅 育 请 家 


图 实例 说 明 
在 本 实例 中 ， 运 用 Jpgraph 生成 折线 图 ， 分 析 网 站 一 天 内 的 访问 走势 ， 其 运行 结果 如 图 6.26 所 示 。 
网 站 一 天 内 流量 分 析 本 
二 
图 6.26 网 站 访问 走势 分 析 
图 关键 技术 


在 本 实例 中 ， 以 一 天 的 十 二 个 时 辰 为 单位 ， 分 析 在 这 十 二 个 时 辰 中 网 站 访问 量 的 走势 。 使 用 了 graph 类 库 创 
建 折线 统计 图 , 除了 需要 在 程序 中 包含 pgraph.php 文件 外 , 还 需要 包含 jpgraph_line.php 文件, 从 而 启用 Jpgraph 
类 库 的 折线 创建 功能 。 其 中 使 用 的 了 graph 技术 如 下 : 

(1) 使 用 LinePlot 对 象 绘制 曲线 。 

通过 Jpgraph 类 库 中 的 LinePlot 类 创建 曲线 ， 该 类 的 语法 如 下 : 

SlinePlot = new LinePlot($data) /创建 折线 图 

参数 $data: 数值 型 数组 ， 指 定 统计 数据 。 

(2) SetFont(0 方 法 统计 图 标题 、 坐 标 轴 等 文字 样式 。 

制作 统计 图 时 ， 需 要 对 图 像 的 标题 、 坐 标 轴 内 文字 进行 样式 设置 ， 在 Jpgraph 类 库 中 ， 可 以 使 用 SetFontO 
实现 ， 该 方法 的 语法 如 下 : 

SetFont(Sfamily, [Sstyle.] [Ssize]) 
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参数 说 明 : 

$family: 指定 文字 的 字体 。 

$style: 指定 文字 的 样式 。 

$size: 指定 文字 的 大 小 ， 默 认为 10。 


(3) SetMargin(0) 方 法 设置 图 像 、 标 题 、 坐 标 轴 上 文字 与 边框 的 距离 ， 其 语法 如 下 ; 


SetMargin(S$left, $right,$top.,$bottom) 

参数 指定 其 与 左右 、 上 下 边框 的 距离 。 
或 者 : 

SetMargin(Sdata) 

参数 $data 同样 指定 与 边框 的 距离 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 
Jpgraph 文件 。 注 意 本 实例 中 创建 的 是 折线 图 ， 所 以 导入 的 文件 也 发 生 了 变化 。 


(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 折线 图 ， 


如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 
include (". /src/ipgraph. php"); 
include ("../src/ipgraph_line.php"); 
// 这 里 省 略 了 创建 数据 的 代码 
Sgraph = new Graph(450,275); 
Sgraph->SetMargin(40,40,40,50); 
Seraph->SetScale("textint"); 
Seraph->SetShadow(O); 


Sgraph->title->Set(iconv("utf-8","gb2312",' 网 站 一 天 内 流量 分 析 )); 


Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD): 
Sgraph->title->SetMargin(10); 
Sgraph->xaxis->SetTickLabels($datas); 
Sgraph->xaxis->SetFont(FF_SIMSUN, FS_BOLD.8); 
Sgraph->xaxis->title->Set("2009-07-21"); 
Sgraph->xaxis->title->SetFont(FF_ARIAL,FS_BOLD); 
Sgraph->xaxis->title->SetMargin(10); 

Spl = new LinePlot($datay); 

S$pl->value->ShowO: 
Spl->value->SetFont(FF_ARIAL.FS_BOLD): 
Spl->value->SetColor("black"."darkred"): 
Spl->SetColor("blue”): 
S$pl->SetFillColor("blue@0.4"); 

Seraph->Add($p)): 

Seraph->Stroke(); 

> 


图 秘笈 心 法 


对 网 站 一 天 内 的 访问 量 走势 进行 分 析 ， 其 关键 代码 


/设置 文件 编码 格式 


/创建 图 像 
/设置 图 像 的 边框 
/定义 刻度 值 的 类 型 
/设置 图 像 阴影 
/定义 标题 

/设置 标题 字 
/设置 标题 字 

1/ 添加 X 轴 上 的 数据 
/定义 字体 

// 设 置 X 轴 的 角 标 
/定义 字体 

/定义 位 置 

/创建 折线 图 像 
/输出 图 像 对 应 的 数据 值 
/定义 图 像 值 的 字体 
/定义 值 的 颜色 
/定义 图 像 颜色 
/定义 填充 颜色 
/添加 数据 
/输出 图 像 


心 法 领悟 294: 创建 不 同 的 图 像 导 入 的 文件 是 有 所 区 别 的 。 


如 果 创 建 柱 形 图 ， 那 么 导入 的 是 : 
include ("../src/ipgraph.php"); 

include ("../src/ipgraph_bar.php"): 

include ("../src/ipgraph_flags.php"); 

如 果 创建 折线 图 ， 那 么 导入 的 是 : 
include ("../src/ipgraph.php"): 

include ("../src/jipgraph_line.php"); 


这 点 必须 注意 ， 如 果 没 有 导入 正确 的 文件 ， 就 不 能 够 完成 图 像 的 创建 操作 。 
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a 二 ole 


图 实例 说 明 
在 本 实例 中 ， 运 用 Jpgraph 实现 柱 形 图 与 折线 图 的 结合 ， 对 2009 年 图 书 销量 和 市 场 占有 率 进行 分 析 ， 其 运 


结果 如 图 6.27 所 示 。 


2009 年 图 蔬 销 量 和 市场 点 有 在 分析 


i 
pe 


图 6.27 2009 年 图 书 销量 和 市 场 占有 率 分 析 


图 关键 技术 


在 本 实例 中 ， 运 用 Jpgraph 对 2009 年 图 书 销量 和 市 场 占有 率 进行 分 析 ， 旨 在 介绍 如 何 实现 柱 形 图 与 折线 图 
的 结合 ， 同 时 渗入 一 个 图 像 注释 的 应 用 。 

柱 形 图 与 折线 图 的 结合 ， 就 是 在 同一 图 像 中 分 别 创建 一 个 柱 形 图 和 一 个 折线 图 ， 与 单独 创建 柱 形 图 和 折线 
图 是 相同 的 ， 唯 一 的 区 别 就 是 要 同时 包含 柱 形 图 文件 和 折线 图 文件 。 

include ("../src/jpgraph.php"); 

include ("../src/jpgraph_line php"); 

include ("../src/ipgraph error.php"): 

include ("../src/ipgraph_bar. php"); 

本 实例 中 添加 了 一 个 图 像 注释 ， 通 过 图 像 的 颜色 来 体现 ， 黄 色 代表 图 书 销量 数据 ， 蓝 色 代表 市 场 占有 率 分 
析 数 据 ， 其 具体 的 关键 技术 如 下 : 

在 创建 的 图 像 对 象 中 ， 应 用 SetLegend0 方 法 添加 注释 的 内 容 ， 其 关键 代码 如 下 : 

$llplot->SetLegend("Sell quantity"): 

其 参数 就 是 指定 要 输出 的 注释 内 容 。 

通过 SetColor0 和 SetFillColor0 方 法 设置 注释 对 应 的 图 像 颜色 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
Jpgraph 文件 。 注 意 本 实例 中 要 导入 的 文件 包括 折线 图 和 柱 形 图 两 种 。 

(2) 应 用 Jpgraph 类 库 中 的 方法 在 同一 图 像 中 创建 一 个 柱 形 图 和 一 个 折线 图 ， 完 成 对 图 书 销量 和 市 场 占有 
下 其 关键 代码 如 下 : 


i "Content-type: text/html:; charset=UTF-8" ); /设置 文件 编码 格式 
include ("../src/ipgraph.php"); 

include ("../src/ipgraph_line.php"); 

include ("../src/ipgraph_error.php"); 

include ("../src/ipgraph bar.php"); 

Slldatay = array(11.9.2.4.3.13.17.23.12.5.19.17): 

Sl2datay = array(23.12.5.19.17.10.15.11.9.2.4.3): 
S$datax=array("Jan","Feb"."Mar"."Apr"."May","Jun"."Jul"."Aug"."Sep"."Oct","Nov","Dec"): 
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$eraph = new Graph(450,275,"auto"); /创建 图 像 
S$graph->img->SetMargin(40.70.20.40); /定义 图 像 边 距 
Sgraph->SetScale("textlin"); /定义 刻度 类 型 
$egraph->SetColor(array(250,250,250)): /定义 颜色 
Sllplot=new LinePlot($lldatay): /创建 图 像 
$llplot->SetColor("blue"): /设置 图 像 颜色 
$llplot->SetWeight(2): /设置 折线 宽度 
Sllplot->SetLegend("Sell quantity"); 

Sl2plot = new BarPlot($l2datay); // 创 建 图 像 
Sl2plot->SetFillColor("orange"); /图 像 填充 颜色 
$l2plot->SetLegend("Market share”): /输出 注释 内 容 
Segraph->Add(Sllplob: /向 图 像 中 添加 数据 
Segraph->Add(Sl2plob: /向 图 像 中 添加 数据 
$egraph->title->Set(iconv("utf-8","gb2312","2009 年 图 书 销量 和 市 场 占有 率 分 析 ")); // 定 义 标题 
Seraph->xaxis->title->Set("Month"); // 定 义 义 轴 角 标 
Sgraph->yaxis->title->Set(iconv("utf-8","gb2312"," 单 位 ， 万 册 》")); /定义 站 轴 标 题 
$egraph->title->SetFont(FF_SIMSUN, FS_BOLD); /定义 字体 
$eraph->yaxis->title->SetFont(FF_SIMSUN, FS_BOLD); /定义 字体 
$egraph->xaxis->title->SetFont(FF_SIMSUN, FS_BOLD):; /定义 字体 
Sgraph->xaxis->SetTickLabels($datax): /定义 义 轴 标题 
Segraph->Stroke0; /生成 图 像 

> 

秘笈 心 法 


心 法 领悟 295: 通过 SetWeight0 方 法 设置 折线 图 折线 的 宽度 。 
在 Jpgraph 类 库 中 ， 创 建 折线 图 时 ， 可 以 通过 es Sle 其 语法 如 下 : 


Sllplot->SetWeight($data); 


$llplot 指 创 建 折线 图 返回 的 对 象 ， 参 数 $data 是 折线 图 折线 的 宽度 值 


图 实例 说 明 


: 
趣味 指数 : 让 


在 本 实例 中 , 运用 Jpgraph 生成 折线 图 , 对 2009 年 牛肉 市 场 的 价格 走势 进行 分 析 , 其 运行 结果 如 图 6.28 所 示 。 


2009 年 牛 内 市场 的 价格 分 析 
28.8 


6.28 ”2009 年 牛肉 市 场 价格 走势 分 析 


图 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创建 折线 图 ， 分 析 2009 年 牛肉 市 场 的 价格 走势 。 虽 在 突出 如 何在 折线 图 中 
输出 格式 化 的 数据 ， 以 及 在 折线 图 的 数据 点 上 添加 标记 。 


(1) 输出 数据 应 用 的 是 value0 对 象 中 的 Show0 方 法 ， 数 据 的 格式 化 应 用 的 是 SetFormat0 方 法 。 
SetFormat($aFormat, $aNegFormat) 
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参数 说 明 : 

$aFormat: 设置 格式 化 的 样式 ; 

$aNegFormat: 设置 negative 的 值 。 

(2) 折线 图 中 标记 的 添加 应 用 的 是 图 像 的 mark 对 象 中 的 SetType0 方 法 ， 其 参数 值 用 于 设置 标记 的 类 型 ， 
语法 如 下 : 

SetType(SaType, SaFileName, SaScale) 

参数 说 明 : 

$aType: 设置 标记 的 类 型 ; 

$aFileName: 插入 图 像 的 名 称 或 者 国家 的 名 称 ; 

$aScale: 设置 插入 标记 的 大 小 。 

SetType0 方法 的 参数 $aType 的 可 选 类 型 包括 MARK SQUARE 、MARK UTRIANGLE 、 
MARK_DTRIANGLE、MARK DIAMOND、MARK_CIRCLE， 这 些 标记 仅 供 参考 ， 如 果 想 了 解 更 多 内 容 请 参考 
Jpgraph 类 库 的 参考 手册 。 


设计 过 程 

(1) 创建 ndex.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 

Jpgraph 文件 。 

(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 2009 年 牛肉 市 场 价格 走势 进行 分 析 ， 其 代码 如 下 : 
Sydata = array(12,18,15,17,16,20,17,13,15,17,15,16); /定义 数据 

$egraph = new Graph(450,300,"auto"); // 创 建 图 像 
Sgraph->SetScale("textlin"); // 定 义 刻度 值 类 型 
S$graph->img->SetMargin(50,40,40,55); // 设 置 边框 的 间距 
S$lineplot=new LinePlot($ydata): // 创 建 折线 图 
Slineplot->mark->SetType(MARK_UTRIANGLE): // 定 义 折线 图 的 标记 点 
Slineplot->value->showO); /输出 折线 图 对 应 的 值 
S$lineplot->value->SetColor('darkred'): // 设 置 值 的 颜色 
S$lineplot->value->SetFont(FF_FONT!1,FS_BOLD): // 设 置 值 的 字体 
$lineplot->value->SetFormat('$960.1f): // 对 值 进行 格式 化 
Sgraph->Add(Slineplot); // 添 加 数据 
$eraph->title->Set(iconv("utf-8","gb2312","2009 年 牛肉 市 场 的 价格 分 析 ")); /定义 标题 
$eraph->xaxis->title->Set(iconv("utf-8","gb2312"," 单 位 ， 元 /月 份 ")); /定义 和 轴 输 出 的 值 
Seraph->xaxis->title->SetMargin(10); /定义 和 轴 输 出 的 值 
Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD): /设置 标题 字体 
Seraph->yaxis->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 Y 轴 内 容 的 字体 
Sgraph->xaxis->title->SetFont(FF_SIMSUN. FS_BOLD): /设置 入 轴 内 容 的 字体 
S$lineplot->SetColor("blue"): 1/ 设置 图 像 颜色 
S$lineplot->SetWeight(2):; /设置 折线 的 宽度 
Sgraph->StrokeO; /生成 图 像 

> 

也 笈 心 法 


心 法 领悟 296: 在 Jpgraph 类 库 中 字体 的 选择 。 
在 Jpgraph 类 库 中 ， 可 以 设置 的 字体 很 多 。 但 是 在 选择 字体 时 必 


须 注 意 ， 有 些 字体 是 不 支持 中 文 的 。 


i 


趣味 指数 :会 宣 依依 前: 


图 实例 说 明 
在 本 实例 中 ， 运 用 pgraph 生成 折线 图 ， 对 公司 2009 年 的 销售 额 进行 分 析 ， 其 运行 结果 如 图 6.29 所 示 。 
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图 6.29 2009 年 公司 的 销售 额 


图 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创建 折线 图 ， 分 析 2009 年 公司 的 销售 额 。 各 


入 的 图 像 设 置 数据 点 标签 。 


突出 如 何在 折线 图 中 通过 插 


实例 296 中 运行 SetType0 方 法 的 第 1 个 参数 ， 直 接 设 置 标签 的 样式 ， 在 本 实例 中 ,运用 SetType0 方 法 的 第 


2 个 参数 , 通过 插入 的 图 像 设 置 数 据点 的 标签 , 并 通过 第 


图 设计 过 程 


3 个 参数 设置 插入 图 像 的 大 小 , 其 语法 请 参考 实例 296。 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 折线 图 ， 

Sdatay1 = array(40.26.15.35.26.15,44.26.15.27.40.15); 
Sgraph = new Graph(650,375); 
Sgraph->SetMarginColor('white’); 
Sgraph->SetScale("textlin"); 
Sgraph->SetFrame(false): 
Sgraph->SetMargin(30,5,35,20); 
$eraph->tabtitle->Set(iconv("utf-8","gb2312",'2009 年 销售 额 分 析 ) ); 
Sgraph->tabtitle->SetFont(FF_SIMSUN. FS_BOLD.12); 
Sgraph->tabtitle->SetColor('darkred',#E1E1FF"); 
Sgraph->xgrid->ShowO); 
Sgraph->xaxis->SetTickLabels($gDateLocale->GetShortMonth(); 
Spl1 = new LinePlot($datay1); 
Sp1->SetColor("navy"); 
Spl->mark->SetType(MARK. IMG,'saab_95.jpg'.0.5); 
S$p1->value->SetFormat('%d ‘iconv("utf-8","gb2312", 万 元 )); 
Spl1->value->Show(); 
Spl->value->SetColor(darkred):; 
Spl->value->SetFont(FF_SIMSUN. FS_BOLD.10); 
Spl->value->SetMargin(14): 
Sp1->SetCenterO; 
Sgraph->Add($p1); 
Seraph->Stroke0; 


力 秘笈 心 法 


对 2009 年 公司 的 销售 额 进行 分 析 ， 其 代码 如 下 : 


/定义 图 像 大 小 
/背景 颜色 
/定义 刻度 值 类 型 


/设置 边 距 

/输出 标题 

/设置 标题 字体 
/设置 标题 颜色 
/设置 阴影 

/定义 入 轴 上 的 数据 
/创建 图 像 
/设置 图 像 颜 色 
/设置 标签 的 样式 ， 使 用 图 片 
/格式 化 数据 

/输出 阴影 

/定义 颜色 

/设置 字体 

/设置 字体 大 小 、 位 置 


/添加 数据 
/生成 图 像 


心 法 领悟 297: 在 Jpgraph 类 库 中 通过 旗帜 来 设置 数据 点 的 标签 。 


通过 旗帜 设置 数据 点 的 标签 ， 同 样 应 用 SetType0 方 


法 ， 只 是 需要 将 第 1 个 参数 设置 为 MARK_FLAG 系列 


(1、2、3、4 表示 旗帜 的 大 小 不 同 ) ， 然 后 将 第 2 个 参数 设置 为 对 应 旗帜 的 表示 即 可 。 
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高 级 
S) | | 
实例 298 趣味 指数 : 女 二 在 
图 实例 说 明 
在 本 实例 中 ， 运 用 了 pgraph 生成 柱 形 图 ， 对 编程 词典 的 销售 比例 进行 分 析 ， 其 运行 结果 如 图 6.30 所 示 。 
编程 词典 销 售 比例 分 析 
se 
三 
| 
| | 
图 6.30 编程 词典 销售 比例 分 析 
图 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创 建 柱 形 图 ， 分 析 编程 词典 的 销售 比例 。 本 实例 中 再 次 创建 柱 形 图 ,与 以 往 
的 有 些 不 同 ， 这 里 将 柱 形 图 顺 时 针 旋转 了 90”。 
主要 应 用 图 像 对 象 中 的 Set90AndMargin0 方 法 ， 完 成 柱 形 图 的 顺 时 针 90” 旋 转 ， 其 语法 如 下 : 


$lm: 左边 框 旋转 角度 ; 
$rm: 右边 框 旋转 角度 ; 
$tm: 上 边框 旋转 角度 ; 
$bm: 下 边框 旋转 角度 。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 
Jpgraph 文件 。 
(2) 应 用 pgraph 类 库 中 的 方法 创建 一 个 柱 形 图 ， 从 另外 一 个 角度 分 析 编 程 词典 的 销售 比例 ， 其 代码 如 下 : 
Sdatay=array(70.50,85,120.50); 
$datax=array("VB"."VC"."JAVA"."C#"."ASP.NET™): 
Swidth=500; /定义 图 像 宽 
Sheight=600; /定义 图 像 高 
Sgraph = new Graph(Swidth.Sheight'auto7): /创建 图 像 
Sgraph->SetScale("textlin"); /定义 刻度 值 类 型 
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=80; 
$bottom = 30; 

Sleft = 80; 

Sright = 50; 
Seraph->Set90AndMargin(Sleft.$right. $top,$bott« 


tom): 
$eraph->title->Set(iconv("utf-8","gb2312"," 编 程 词 典 销售 比例 分 析 ")): 


Sgraph->title->SetFont(FF_SIMSUN, FS BOLD.14): 
Sgraph->subtitle->Set("(2009-06)"); 
Seraph->xaxis->SetTickLabels($datax); 


Seraph->xaxis->SetFont(FF_ VERDANA.FS NORMAL.12): 


$graph->xaxis->SetLabelAlign(rightvcenter): 
Seraph->yaxis->scale->SetGrace(20); 
Seraph->yaxis->SetLabelAlign('center',bottom’); 
Seraph->yaxis->SetLabelAngle(45); 
Sgraph->yaxis->SetLabelFormat(%d); 


Seraph->yaxis->SetFont(FF_ VERDANA.FS_ NORMAL.12): 


Sbplot = new BarPlot(Sdatay); 
$bplot->SetFillColor("orange"); 
Sbplot->SetShadowO; 

$bplot->value->ShowO; 
$bplot->value->SetFont(FF_ARIAL.FS_BOLD.,12); 
S$bplot->value->SetAlign(left','center’): 
$bplot->value->SetColor("black","darkred"); 
Sbplot->value->SetFormat('%. 1f); 
Sgraph->Add($bplot); 

Sgraph->StrokeO); 


图 秘笈 心 法 


/设置 图 像 的 边 下 


/定义 和 X 轴 上 的 数据 

/设置 字体 
/设置 站 轴 上 字体 右 侧 居中 

// 设 置 Y 轴 间距 

// 设 置 Y 轴 字体 居中 ， 底 部 对 齐 
/设置 字体 的 倾斜 度 

/输出 数据 的 格式 


/设置 数据 颜色 
/格式 化 数据 
/添加 数据 
/生成 图 像 


心 法 领悟 298: 在 Jpgraph 类 库 中 控制 坐标 轴 上 标签 的 位 置 。 
在 Jpgraph 类 库 中 ,控制 坐标 轴 上 标签 的 位 置 应 用 的 是 SetLabelAlign0 方 法 ,在 本 实例 中 多 次 使 用 了 这 个 方 
法 ， 完 成 对 数据 在 边框 和 坐标 上 位 置 的 控制 。 


图 实例 说 明 


在 本 实例 中 ， 运 用 Jpgraph 生成 饼 形 图 ， 对 公 


趣味 指数 : 人 


司 年 度 图 书 销量 情况 进行 分 析 ， 其 运行 结果 如 图 6.31 所 示 。 


6.31 2009 年 图 书 销量 分 析 


图 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创 建 饼 形 图 ， 分 析 2009 年 图 书 销量 情况 ， 旨 在 突出 饼 形 图 的 创建 方法 ， 其 


应 用 的 关键 技术 如 下 : 


(1) 创建 饼 形 图 图 像 应 用 PieGraph 类 ， 该 类 继承 Graph 类 ， 创 建 3D 饼 形 图 的 图 像 。 
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(2) 创建 3D 饼 形 图 应 用 PiePlot3D 类 ， 该 类 继承 PiePlot 类 。 
(3) 通过 图 像 中 的 legend 对 和 象 调用 Pos0 方 法 定位 饼 形 图 在 图 像 中 的 存储 位 置 。Pos0 方 法 的 语法 如 下 : 
Pos(Sax, SaY. SaHAlign, SaVAlign) 
参数 说 明 : 
$aX: 设置 距离 义 轴 的 位 置 ; 
$aY: 设置 距离 了 轴 的 位 置 ; 
$aHAlign: 设置 右 侧 (居中 、 居 左 或 者 居 右 ); 
$aVAlign: 设置 顶部 〈 居 下 、 居 上 或 者 居中 ) 。 
(4) 通过 人 饼 形 图 对 象 调用 SetTheme( 方 法 设置 饼 形 图 的 颜色 。SetTheme( 方 法 的 语法 如 下 : 
PiePlot :: 
参数 $aTheme 指定 主题 的 名 称 ， 其 支持 的 主题 包括 earth、pastel、sand、water。 
设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2009 图 书 销量 进行 分 析 ， 其 代码 如 下 : 
ee "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 


include ("../src/ipgraph.php"); 
include ("../src/jpgraph_pie.php"); 
include ("../src/ipgraph pie3d.php"); 
$data = amray(20.27,45.75.90.30); 


$egraph = new PieGraph(500,275,"auto"); 1/ 创建 图 像 
S$graph->SetShadowO; /输出 阴影 
$egraph->tabtitle->Set(iconv("utf-8","gb2312",'2009 年 图 书 销售 分 析 ) ) /输出 标题 
$egraph->tabtitle->SetFont(FF_SIMSUN, FS_BOLD.18): /设置 标题 字体 
$egraph->title->SetColor("darkblue"); /定义 标题 颜色 
$eraph->legend->Pos(0.1,0.2); /| 控制 注释 文字 的 位 置 
Sp1 = new PiePlot3d($data): /1/ 创 建 3D 饼 形 图 图 像 
$p1->SetTheme("water"); /控制 图像 颜色 的 主题 
$p1->SetCenter(0.35); /控制 图 像 的 大 小 比例 
$p1->SetAngle(30); /控制 图 像 的 倾斜 角度 
S$pl->value->SetFont(FF_ARIAL.FS NORMAL.12): /设置 字体 
Spl->SetLegends(array("ASP.NET"."C#"."JAVA"."PHP"."VB","VC")); 

$egraph->Add($p1); /添加 数据 
S$graph->StrokeO; /生成 图 像 

> 

秘笈 心 法 


心 法 领悟 299: 在 了 pgraph 类 库 中 控制 饼 形 图 大 小 和 倾斜 角度 的 方法 。 
在 Jpgraph 类 库 中 ， 通 过 饼 形 图 对 象 中 的 SetCenter0 方 法 控制 饼 形 图 的 大 小 比例 ， 默 认 值 是 0.5; 通过 
SetAngle0 方 法 控制 图 像 的 倾斜 角度 ， 倾 斜 角度 必须 在 10”~80” 之 间 。 


实例 300 


趣味 指数 : | 


力 实例 说 明 
在 本 实例 中 , 运用 Jpgraph 生成 饼 形 图 ， 对 公司 各 语言 编程 词典 的 销售 比例 进行 分 析 ， 其 运行 结果 如 图 6.32 
所 示 。 
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编程 词 费 销售 比例 分 析 


图 6.32 编程 词典 销售 比例 


力 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创建 饼 形 图 ， 分 析 2009 年 各 语言 编程 词典 的 销售 比例 ， 旨 在 突出 饼 形 图 的 


创建 方法 ， 其 应 用 的 关键 技术 如 下 : 


(1) 创建 饼 形 图 图 像 应 用 PieGraph 类 ， 该 类 继承 Graph 类 ， 创 建 3D 饼 形 图 的 图 像 。 
(2) 创建 3D 饼 形 图 应 用 PiePlot3D 类 ， 该 类 继承 PiePlot 类 。 
(3) 通过 ExplodeSlice( 方 法 对 饼 形 图 进行 分 割 ， 其 语法 如 下 : 


ExplodeSlice($e, $radius) 

参数 说 明 : 

$e: 指定 分 割 的 区 块 ， 

$radius: 指定 分 割 的 区 块 与 原 图 的 距离 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 


(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 饼 形 图 ,对 2009 年 各 语言 编程 词典 的 销量 进行 分 析 ， 其 代码 


如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/ipgraph.php"); 
include ("../src/ipgraph pie.php"); 
include ("../src/jpgraph_pie3d.php"); 
$data = amray(20.15.30.30.15); 
Sdatas = array("CH", "VB", "VC", "JAVA", "ASP NET"); 
Sgraph = new PieGraph(450,240."auto"); 
Sgraph->SetShadowO; 


S$graph->title->Set(iconv("utf-8","gb2312"," 编 程 词典 销售 比例 分 析 ")); 


Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): 
S$pl = new PiePlot3D($data): 
$p1->ExplodeSlice(4.50): 

S$p1->SetCenter(0.35); 

S$pl->SetLegends(Sdatas); 

Seraph->Add($p1); 

Sgraph->StrokeO); 


> 
图 秘笈 心 法 
心 法 领悟 300: 如 何 保持 3D 饼 形 图 的 完整 性 。 


在 了 pgraph 类 库 中 创建 3D 饼 形 图 时 ， 如 果 不 应 用 ExplodeSlice0 方 法 ， 那 么 创建 的 3D 饼 形 图 就 是 完整 的 ; 


/设置 文件 编码 格式 


/设置 统计 数据 
/创建 图 像 

// 创 建 图 像 阴影 

/定义 标题 

/设置 标题 字体 
/生成 饼 形 图 

/设置 饼 形 图 分 割 位 置 
/设置 饼 形 图 在 图 像 中 的 存储 位 置 
/设置 说 明文 字 的 内 容 
/添加 数据 

/生成 图 像 


如 果 应 用 Explode0 方 法 ， 将 一 个 数组 值 作为 参数 ， 那 么 就 可 以 实现 3D 饼 形 图 的 多 块 分 割 。 
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图 实例 说 明 


a 
注 


趣味 指数 : ohodolots | 


在 本 实例 中 , 运用 Jpgraph 生成 多 饼 形 图 区 块 , 对 公司 2009 年 图 书 销量 进行 分 析 , 其 运行 结果 如 图 6.33 所 示 。 


图 6.33 ”2009 年 图 书 销量 分 析 


图 关键 技术 


在 本 实例 中 ,通过 了 pgraph 类 库 创 建 饼 形 图 ， 应 用 人 饼 形 图 对 象 中 的 Explode0 方 法 完成 对 2009 年 各 部 门 图 书 


销量 的 分 块 展 示 。Explode0 方 法 的 语法 如 下 : 


Explode($aExplodeArr) 


该 方法 将 饼 形 图 分 割 成 多 个 模块 ， 参 数 $aExplodeArr 是 一 个 数组 ， 根 据 数组 元 素 个 数 定义 分 割 数量 ， 根 据 


数组 元 素 值 定义 分 割 后 模块 与 原 图 像 的 距离 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 


(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2009 年 图 书 销量 进行 分 析 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/ipgraph.php"): 

include ("../src/ipgraph_pie.php"); 

include ("../sre/ipgraph_pie3d.php"); 

$data = array(20.27.45.75.90.30); 

Sgraph = new PieGraph(500.245."auto"); 
Segraph->SetShadowO; 


Sgraph->tabtitle->Set(iconv("utf-8"."gb2312",2009 年 图 书 销售 分 析 ") ): 


Sgraph->tabtitle->SetFont(FF_SIMSUN. FS_BOLD.14); 
Sgraph->title->SetColor("darkblue"); 
Sgraph->legend->Pos(0.1,0.2); 

Sp1 = new PiePlot3d($data); 
Spl->SetTheme("sand"): 

Sp1->SetCenter(0.4); 

Sp1->SetSize(0.4); 

Sp1->SetHeight(20): 

Sp1->SetAngle(45); 
Sp1->Explode(array(5.40,10,30.20)): 
Spl->value->SetFont(FF_ARIAL.FS_NORMAL.10): 


Sp1->SetLegends(array("ASP.NET","C#"."JAVA","PHP"."VB","VC")): 


Sgraph->Add($p1); 
Seraph->Stroke0: 
> 


/设置 文件 编码 格式 


// 创 建 图 像 

// 创 建 图 像 阴 影 
/输出 标题 

/设置 标题 字体 
/定义 标题 颜色 
/特制 注释 文字 的 位 置 
// 创 建 图 像 

/| 控制 图 像 颜 色 

// 设 置 图 像 位 置 

// 设 置 图 像 大 小 

/设置 饼 形 图 高 度 
/设置 图 像 倾斜 角度 
/| 控制 饼 形 图 的 分 割 
/设置 字体 


/添加 数据 
/生成 图 像 
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图 秘笈 心 法 


心 法 领悟 301: 设置 3D 饼 形 图 的 高 度 。 
在 了 pgraph 类 库 中 设置 3D 饼 形 图 的 高 度 ， 应 用 饼 形 图 对 象 中 的 SetHeight0 方 法 。 


实例 302 


图 实例 说 明 
在 本 实例 中 ， 运 用 pgraph 类 库 在 同一 图 像 中 生成 多 个 饼 形 图 ， 对 公司 2009 年 上 
析 ， 其 运行 结果 如 图 6.34 所 示 


年 编程 词典 销量 进行 分 


图 6.34 2009 年 上 半年 编程 词典 销量 分 析 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创 建 多 饼 形 图 ， 其 实现 的 关键 是 数组 和 for 循环 语句 的 运用 。 饼 形 图 创建 的 
原理 与 上 面 介绍 的 是 相同 的 ， 只 是 这 里 根据 传递 的 数组 数据 ， 对 人 饼 形 图 的 创建 方法 执行 了 循环 操作 ， 进 而 完成 
多 人 饼 形 图 的 创建 。 

其 中 关键 的 内 容 就 是 输出 的 数据 、 饼 形 图 的 坐标 定义 和 人 饼 形 图 标题 的 设置 ， 根 据 这 3 个 数组 数据 ， 然 后 执 
行 for 循环 ， 完 成 饼 形 图 的 创建 ， 其 关键 代码 如 下 : 


Sdata = array( // 定 义 输出 的 数据 
array(80.18.15.17.50.90). 
array(35.90.70.34.60.120). 
array(40.68.70.50.80.100). 
array(60.22.80.40.100.90)): 
Spiepos = array(0.2.0.4.0.65.0.28.0.25.0.75.0.8.0.75): /定义 饼 形 图 的 坐标 
Stitles = array('C#,JAVA''VB''VC): /定义 标题 
Sn = count(Spiepos)/2: /| 统计 饼 形 图 的 个 数 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 includeO 语 句 导 入 所 需 的 存储 在 章 文 件 夹 06 下 的 
Jpgraph 文件 。 


(2) 根据 定义 的 坐标 值 数组 ， 计 算出 饼 形 图 的 个 数 ， 应 用 Jpgraph 类 库 中 的 方法 ， 通 过 for 循环 创建 多 个 
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人 饼 形 图 ， 其 代码 如 下 : 


Sgraph = new PieGraph(650,500,auto'); 
Seraph->SetMargin(1.1.40.1): 
Sgraph->SetMarginColor(navy’); 
S$eraph->SetShadow(false): 


Sgraph->SetBackgroundImage(worldmap1.jpg.BGIMG FILLPLOT); 


// 创 建 图 像 
/定义 图 像 的 边 距 
/定义 边 距 的 颜色 


/添加 背景 图 像 


Seraph->title->Setticonv(rutf8""gb2312"2009 年 上 半年 编程 词典 销售 分 析 9): 


Seraph->title->SetFont(FF_SIMSUN, FS_BOLD.18); 
Seraph->title->SetColor('white'); 
S$p = arrayO; 
for( $i=0; $i< $n; ++$i) { 
Sd="dataSi"; 
S$p[] = new PiePlot3D($data[$i]); 
} 


for( $i=0; $i< Sn; ++$i) { 


S$p[$i]->SetCenter(Spiepos[2*$i],Spiepos[2*$i+1]); 


} 

for( $i=0; $i < Sn; +HSi){ 
Sp[$i]->title->Set(Stitles[$i]); 
Sp[$i]->title->SetColor('white); 
Sp[$i]->title->SetFont(FF_ARIAL.FS_BOLD.10); 


} 

for( $i=0; Si< $n; ++$i) { 
Sp[$i]->value->SetFont(FF_ARIAL.FS_BOLD): 
Sp[$i]->value->SetColor(white’); 


} 

for( $i=0; $i < $n; ++$i) { 
Sp[$il->value->Show(); 

} 

for( $i=0; $i < $n; ++8i) { 
Sp[$i]->value->SetFormat("9%%01.1f9696"); 


} 

for( $i=0; $i < $n; ++8i) { 
S$p[$i]->SetSize(0.15); 

for( $i=0; Si < Sn; ++8i) { 


Sp[$il->SetEdge(false): 
Sp[$il->ExplodeSlice(5); 


} 
S$p[0]->SetLegends(array("Jan","Feb","Mar”","Apr","May”,"Jan")); 


S$graph->legend->Pos(0.05,0.35); 

Sgraph->legend->SetShadow(false): 

for( $i=0; $i< $n; ++$i) { 
Sgraph->Add($p[$i]): 


} 
Sgraph->Stroke(); 


力 秘笈 心 法 


像 中 的 位 置 ， 并 且 执行 正确 的 循环 操作 ， 那 么 多 饼 形 图 的 创建 就 不 是 问题 ， 至 于 创建 的 方法 与 单个 饼 形 


心 法 领悟 302: 同一 图 像 中 多 饼 形 图 的 创建 。 


/定义 空 数 组 
/根据 饼 形 图 的 个 数 


/创建 3D 饼 形 图 


// 定 义 饼 形 图 的 位 置 
/循环 输出 饼 形 图 的 标题 
/输出 标题 

/定义 颜色 

/定义 字体 

// 循 环 读 取 饼 形 图 的 数据 
/定义 字体 

/定义 颜色 
/设置 数据 的 输出 阴影 
/定义 输出 数据 的 格式 
/数据 的 格式 化 


/定义 图 像 大 小 


/定义 分 割 的 饼 形 图 块 


/定义 注释 内 容 
/定义 注释 的 坐标 


// 循 环 执行 饼 形 图 数据 的 添加 操作 


/生成 图 像 


在 同一 图 像 中 创建 多 个 饼 形 图 的 关键 是 如 何 完成 数据 的 循环 读 取 ， 只 要 能 够 准确 地 定位 每 个 饼 形 图 在 图 


同 的 。 


实例 303 


图 实例 说 明 


在 本 实例 中 , 运用 Jpgraph 类 库 生 成 环 饼 形 图 , 对 公司 2009 年 图 书 销量 进行 分 析 , 其 


高 级 
趣味 指数 : 寅 穴 全 催办 


运行 结果 如 图 6.35 所 示 。 
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2009 年 图 书 销售 分 析 


图 6.35 2009 年 图 书 销量 分 析 


力 关键 技术 


在 本 实例 中 ， 通 过 Jpgraph 类 库 创 建 环 饼 形 图 ， 对 2009 年 各 部 门 图 书 销量 进行 分 析 ， 并 且 通 过 创建 的 文本 
输出 说 明 信 息 ， 其 应 用 的 关键 技术 如 下 : 
(1) 通过 PiePlotC 类 创建 环 饼 形 图 图 像 ， 该 类 继承 PiePlot 类 。 
(2) 通过 环 饼 形 图 中 的 midtitle 对 象 调用 Set0 方 法 输出 环 饼 形 图 的 中 心 标题 ， 调 用 SetFont() 方 法 设置 中 心 
标题 的 字体 。 
(3) 通过 Text 类 在 图 像 中 定义 文本 ， 其 参数 为 向 文本 中 添加 的 数据 。 


设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存储 在 章 文 件 夹 06 下 的 
Jpgraph 文件 。 


(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 环 饼 形 图 ， 对 2009 年 图 书 销量 进行 分 析 ， 并 通过 文本 输出 说 明 信 
息 ， 其 代码 如 下 : 


<?php 


header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
include ("../src/ipgraph.php"); 
include ("../src/ipgraph_pie.php"); 
Sdata = atray(50.28.25.27.31.20); 
$egraph = new PieGraph(400,400); /创建 图 像 
$egraph->title->Set(iconv("utf-8"."gb2312".'2009 年 图 书 销售 分 析 )); // 设 置 标题 文字 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD.18): /设置 字体 
Seraph->title->SetMargin(8): // 设 置 边 距 
S$p1 = new PiePlotC($data): /创建 图 像 
$p1->SetSize(0.32); /设置 图 像 大 小 
$p1->SetCenter(0.5.0.45); /定义 图 像 存储 位 置 
S$pl->value->SetFont(FF_ARIAL.FS_BOLD.12): // 设 置 数据 的 字体 
S$p1->value->SetColor('white); // 设 置 字体 颜色 
$p1->midtitle->Set(iconv("utf-8"."gb2312"." 明 日 科技 ")); /输出 中 心 内 容 
Spl->midtitle->SetFont(FF_SIMSUN. FS_BOLD.14): /设置 字体 
S$p1->SetMidColor(yellow"); /设置 中 心 图 像 颜色 
SIbl = amray("ASPNET96.1B6b96"."Cifhn96.1f696"."JAVAW96.1f9696" 
"PHP\n%.1f9%","VB\n%.1f9%","VC\n%%.189496"); /定义 数据 内 容 
Sp1->SetLabels($IbD):; 
$p1->SetShadow0: // 生 成 阴影 
$p1->ExplodeAll(20); // 定 义 图 像 大 小 


S$txt = new Text(iconv("utf-8"."gb2312"."2009 年 各 语言 出 版 图 书 所 占 市 场 份 额 ")); 
Stxt->SetFont(FF SIMSUN., FS BOLD.12); 


/创建 文本， 并 添加 数据 


S$txt->Pos(0.5,0.97.'center', bottom’): /设置 存储 位 置 
Stxt->SetBox('yellow','black’); /设置 颜色 
Stxt->SetShadowO; /设置 图 像 阴影 
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S$egraph->AddText(Stxt): /| 添加 数据 


Sgraph->Add($p1): // 向 图 像 中 添加 数据 
$eraph->StrokeCSIMO: // 生 成 图 像 
> 

图 秘笈 心 法 


心 法 领悟 303: Jpgraph 类 库 的 应 用 总 结 。 

在 6.3 节 的 实例 中 ， 笔 者 对 Jpgraph 类 库 中 常用 的 图 像 创 建 方法 进行 了 讲解 。 由 于 笔者 的 水 平 有 限 ， 在 讲解 
过 程 中 难免 有 下 漏 之 处 ， 还 请 读者 见谅 。 

最 后 ， 教 大 家 一 个 学 习 和 运用 Jpgraph 类 库 的 好 方法 。 读 者 在 下 载 pgraph 类 库 时 ， 在 下 载 的 文件 中 包含 一 
个 docportal 文件 夹 ， 在 这 个 文件 夹 中 存储 了 卫 graph 类 库 中 方法 、 对 象 和 类 的 详细 说 明 ， 读 者 如 果 有 不 明之 处 
可 以 在 这 个 参考 手册 中 寻找 答案 。 另 外 ， 在 下 载 的 src 文件 夹 中 ， 还 包含 了 一 个 Examples 文件 夹 ， 在 这 个 文件 
夹 中 存储 了 很 多 Jpgraph 类 库 创建 图 像 的 实例 ， 读 者 可 以 根据 自己 的 需求 进行 选择 。 


6.4 GD2 函数 库 


GD2 函数 库 在 图 像 图 形 绘制 方面 功能 非常 强大 ， 开 发 人 员 既 可 以 在 已 有 图 片 的 基础 上 进行 绘制 ， 也 可 以 在 
没有 任何 素材 的 基础 上 绘制 。 


aa 


中 级 | 
趣味 指数 : 容 侠 页 而 


图 实例 说 明 

应 用 GD2 函数 可 以 绘制 的 图 形 有 多 种 ， 最 基本 的 图 形 包 括 线条 、 圆 、 方 形 等 ， 无 论 开发 人 员 绘制 多 么 复杂 
的 图 形 都 是 在 这 些 最 基本 的 图 形 基础 上 进行 深化 的 ， 只 有 掌握 了 最 基本 图 形 的 绘制 方法 ， 才 能 够 绘制 出 各 种 具 
有 独特 风格 的 图 形 。 在 本 实例 中 ， 将 讲解 这 些 基 本 几何 图 形 的 绘制 方法 ， 运 行 结果 如 图 6.36 所 示 。 


6.36 绘制 基本 几何 图 形 


图 关键 技术 


在 GD2 函数 库 中 分 别 应 用 imageline0 函 数 、imagearc0 函 数 和 imagerectangle0 函 数 绘制 直线 、 圆 形 和 方形 。 

imageline0 函 数 ， 用 于 绘制 直线 ， 其 语法 如 下 : 

bool imageline ( resource image, int x1, int yl. int x2. int y2. int color ) 

该 函数 用 颜色 color 在 图 像 image 中 从 坐标 (x1，y1) 到 (x2，y2) (图 像 左上 角 坐 标 为 (0, 0)) 绘制 一 
条 线段 。 

imagearc() 函 数 ， 用 于 绘制 圆 形 ， 其 语法 如 下 : 

bool imageare ( resource image. int cx. int cy. int w, int h, int s, int e, int color ) 


imagearc0) 函 数 的 参数 说 明 如 表 6.3 所 示 。 
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表 6.3 imagearc(0 函 数 的 参数 说 明 


参 数 说 了 明 

image 表示 图 像 的 handle 

Cis CY 原点 坐标 〈0.0) 为 图 片 的 左上 角 ， 参 数 cx、cy 为 椭 
W、h 参数 w、h 为 水 平 轴 长 和 垂直 轴 长 

i 分 别 为 起 始 角 与 结束 角 

color 弧 线 的 颜色 


imagerectangle0 函 数 ， 用 于 绘制 方形 ， 其 语法 如 下 : 

bool imagerectangle ( resource image, int x1, int y1, int x2, int y2, int col ) 

该 函数 用 颜色 col 在 图 像 image 中 绘制 一 个 方形 ， 其 左上 角 坐 标 为 (x1, y1) ， 右 下 角 坐 标 为 (x2,y2) 。 图 
像 的 左上 角 坐 标 为 0.0) 。 


设计 过 程 

应 用 GD2 函数 最 基本 的 图 形 绘制 函数 ， 分 别 绘制 直线 、 正 圆 和 正方 形 , 并 用 白色 作为 线条 基色 ,代码 如 下 : 
<?php 

header("Content-type: image/png"); // 将 图 像 输出 到 浏览 器 

Simg = imagecreate(560, 200); // 创 建 一 个 560X200 的 图 像 
$bg = imagecolorallocate($img, 0. 0, 255); // 设 置 图 像 背景 色 

S$white = imagecolorallocate($img, 255, 255, 255); /设置 绘制 图 像 的 颜色 为 白色 
imageline($img, 20, 20, 150, 180, $white): // 绎 制 一 条 直线 
imagearc($img, 250, 100, 150, 150. 0, 360, S$white); /| 维 制 一 个 贺 
imagerectangle($img, 350, 20, 500, 170, Swhite): // 绎 制 一 个 正方 形 
imagepng($img): /以 .png 格式 输出 图 形 
imagedestroy($img): /释放 资源 

> 
秘笈 心 法 


心 法 领悟 304: 在 PHP 中 如 何 激活 和 屏蔽 GD2 函数 库 。 

GD 库 是 在 PHP5 中 默认 安装 的 ， 但 是 要 想 激 活 GD 库 ， 必 须 修 改 php.ini 文件 。 将 该 文件 中 
的 :extension=php_gd2.dll 选项 前 的 分 号 “;” 去 掉 ， 保 存 文件 并 重新 启动 Apache 服务 器 即 可 生效 。 如 果 要 屏蔽 对 
GD2 函数 库 的 支持 ， 则 在 extension=php_gd2.dll 选项 前 加 上 分 号 即 可 。 


实例 305 


图 实例 说 明 


使 用 GD2 函数 不 仅 可 以 绘制 线条 图 形 ， 还 可 以 绘制 填充 图 形 ， 如 填充 贺 形 、 填 充 算 形 等 ， 在 本 实例 中 ， 将 
介绍 圆 形 和 和 矩形 的 填充 ， 其 运行 结果 如 图 6.37 所 示 。 


图 6.37 填充 几何 图 形 
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图 关键 技术 


在 GD2 函数 库 中 ， 应 用 imagefill0 函 数 实现 图 像 的 填充 操作 ， 其 语法 如 下 : 

bool imagefill ( resource image, int x, int y, int color) 

该 函数 在 图 像 image 的 坐标 (x，y) (图 像 左上 角 坐 标 为 (0, 0) ) 处 用 颜色 color 执行 区 域 填充 〈 即 与 (x， 
y) 点 颜色 相同 且 相 邻 的 点 都 会 被 填充 ) 。 

应 用 imagefilledarcO 函 数 绘制 一 个 椭圆 弧 线 ， 其 语法 如 下 : 

bool imagefilledarc (resource image, int cx, int cy, int w, int h, int s, int e. int color. int style ) 

该 函数 在 image 所 代表 的 图 像 中 以 (cx，cy) 《图 像 左上 角 坐标 为 《0, 0) ) 为 坐标 点 绘制 一 椭圆 弧 。 如 果 
成 功 返 回 TRUE, 否则 返回 FALSE.。 参数 w 和 了 分 别 指定 椭圆 的 宽 和 高 ;s 和 e 以 角度 指定 起 始 和 结束 点 ; style 
可 以 是 下 列 值 按 位 或 (OR) 后 的 值 : 

加 IMG ARC PIE。 

加 IMG ARC CHORD. 

加 IMG ARC NOFILL。 

加 IMG ARC EDGED. 

IMG _ARC PIE 和 IMG_ARC_CHORD 是 互 斥 的 。IMG _ARC_CHORD 只 是 用 直线 连接 起 始 和 结束 点 ， 而 
IMG ARC _PIE 则 产生 圆 形 边界 (如 果 两 个 都 用 ，IMG_ARC_CHORD 生效 ) ; IMG _ARC NOFILL 指明 弧 或 弦 
只 有 轮廓 ， 不 填充 ，IMG_ARC_ EDGED 指明 用 直线 将 起 始 和 结束 点 与 中 心 点 相连 ， 和 IMG_ARC NOFILL 
起 使 用 是 绘制 饼 状 图 轮廓 的 好 方法 〈 不 用 填充 ) 。 

应 用 ImagefilledellipseO 函 数 绘制 一 个 李 圆 ， 其 语法 如 下 : 


bool imagefilledellipse ( resource image, int cx, int cy, int w, int h, int color ) 
该 函数 在 image 所 代表 的 图 像 中 以 (cx，cy) 〈 图 像 左上 和 角 坐 标 为 〈0,0) ) 为 中 心 绘制 一 个 椭圆 。 参 数 w 
h 分 别 指定 椭圆 的 宽 和 高 ，color 指定 填充 颜色 。 如 果 成 功 返 回 TRUE， 否 则 返回 FALSE。 


图 设计 过 程 
本 实例 应 用 GD2 函数 绘制 填充 椭圆 形 和 填充 正方 形 ， 其 代码 如 下 : 
el "Content-type: image/png"): // 将 图 像 输 出 到 浏览 器 
Simg = imagecreate(400, 200); /创建 一 个 400X 180 的 图 像 


$bg = imagecolorallocate($img, 0, 0, 255); 

Swhite = imagecolorallocate($img, 255, 0. 255); 

imagefilledellipse($img, 100. 100, 150. 150, $white); /| 绘制 贺 形 
imagefilledrectangle($img, 200, 50. 300, 150, Swhite); /| 颇 制 正方 形 
imagepng($img): 

多 


图 秘笈 心 法 


心 法 领悟 305: 通过 GD2 函数 库 创建 图 像 必 不 可 少 的 函数 。 
在 通过 GD2 函数 库 创建 图 像 时 ，imagedestroy0 函 数 是 必 不 可 少 的 ， 可 以 通过 它 销毁 指定 的 图 像 ， 释 放 与 
image 关联 的 内 存 。 如 果 不 应 用 该 函数 ， 与 image 关联 的 数据 将 会 一 直 存 储 在 内 存 中 。 


力 实例 说 明 
在 本 实例 中 ， 介 绍 如 何在 图 像 中 输出 字符 串 〈 注 意 这 里 介绍 的 是 如 何 输出 英文 字符 串 ) ， 其 运行 效果 如 
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图 6.38 所 示 。 
Do you still love php tomorrow ? 
图 6.38 输出 英文 字符 串 
图 关键 技术 


GD2 函数 库 中 应 用 imageStringO 函 数 在 画布 上 输出 字符 串 ， 其 语法 如 下 : 

bool imagestring ( resource image, int font int x, int y, string s, int col ) 

该 函数 用 颜色 col 将 字符 串 s 绘制 到 image 所 代表 的 图 像 的 (X，y) 处 〈 这 是 字符 串 的 左上 角 坐 标 ， 整 幅 图 
像 的 左上 角 坐 标 为 《0，0) ) 。 如 果 font 是 1、2、3、4 或 5， 则 使 用 内 置 字体 。 


图 设计 过 程 


本 实例 应 用 imageStringO 函 数 在 画布 上 水 平地 绘制 一 行 英文 字符 串 ， 其 代码 如 下 : 
<?php 


imagestring($in, 5, 0, 0, "Do you still love php tomorrow ?" Sred); /在 指定 的 坐标 处 ， 水 平地 绘制 一 行 红色 的 字符 串 
imagepng($im); /输出 图 像 
imagedestroy($img); /| 销毁 图 像 
> 
图 秘笈 心 法 


心 法 领悟 306: 如 果 要 输出 中 文字 符 串 应 该 怎么 办 ? 
在 GD2 函数 库 中 ， 想 要 输出 中 文字 符 串 ， 必 须 将 中 文字 符 串 的 编码 格式 转换 成 utf8， 然 后 应 用 


中 级 
超 味 指数 : 寅 全 页 催 ; 


实例 307 


力 实例 说 明 


PHP 中 的 GD 库 支 持 中 文 ， 但 必须 要 以 utf-8 格式 的 参数 来 进行 传递 ， 如 果 使 用 imageStringO 函 数 直接 绘制 
中 文字 符 串 就 会 显示 乱码 。 这 是 因为 GD2 对 中 文 只 能 接收 utf-8 编码 格式 ， 并 且 默认 使 用 了 英文 的 字体 ， 所 以 
要 输出 中 文字 符 串 ， 必 须 对 其 进行 转 码 ， 并 设置 中 文字 符 使 用 的 字体 。 否 则 ， 输 出 的 只 能 是 乱码 。 在 本 实例 中 ， 
实现 GD2 函数 输出 中 文字 符 串 ， 并 且 通 过 GD2 函数 将 中 文字 符 串 在 照片 上 输出 ， 其 运行 结果 如 图 6.39 所 示 。 


6.39 在 照片 上 输出 中 文字 符 串 


Pe 
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图 关键 技术 
在 PHP 中 ， 在 图 像 中 添加 中 文字 符 串 应 用 的 是 imagettftext 0 函数 ， 其 语法 如 下 : 
array imagettfiext ( resource image, float size, float angle. int x, int y, int color string fontfile. string text ) 


imagettftext 0 函数 的 参数 说 明 如 表 6.4 所 示 。 
表 6.4 imagettftext () 函 数 的 参数 说 明 


参 数 说 了 明 
image 图 像 资源 
size 字体 大 小 。 根 据 GD 版 本 不 同 ， 应 该 以 像素 大 小 (GD1) 或 点 大 小 (GD2) 指定 
i 0 顺 时 针 计 算 ，0” 为 水 平 ， 也 就 是 3 点 钟 的 方向 〈 由 左 到 右 ) ，90” 则 为 由 下 到 上 的 
x 文字 的 义 坐标 值 。 设 定 第 一 个 字符 的 基本 点 
y 文字 的 Y 坐标 值 。 设 定 字体 基线 的 位 置 ， 不 是 字符 的 最 底 端 
color 文字 的 颜色 
fontfile 字体 的 文件 名 称 ， 也 可 以 是 远 端的 文件 
text 字符 串 内 容 


在 PHP 中 ， 通 过 GD2 函数 对 JPG 格式 的 照片 进行 操作 应 用 imagecreatefromjpeg0 函 数 ， 根 据 了 PEG 文件 或 
URL 新 建 一 图 像 ， 其 语法 如 下 : 

Tesource imagecreatefromjpeg ( string filename ) 

参数 flename 可 以 是 本 地 文件 ， 也 可 以 是 网 络 的 URL 地址。 返回 值 为 了 PEG 的 文件 代码 ， 可 供 其 他 函数 使 
用 。 该 函数 在 失败 时 返回 一 个 空 字符 串 ， 并 且 输 出 一 条 错误 信息 。 


设计 过 程 

本 实例 应 用 imagecreatefromjpeg0 和 imagettftext 0 函数 在 照片 上 添加 中 文字 符 串 ， 其 代码 如 下 : 
<?php 

header("content-type:image/jpeg"); /定义 输出 为 图 像 类 型 
Sim=imagecreatefromjpeg("images/P1020494.JPG"): /1/ 戴 入 照片 
Stextcolor=imagecolorallocate($im.25,25,136); // 设 置 字体 颜色 为 蓝 色 ， 值 为 RGB 颜色 值 
S$font="Font/mzd.ttf"; /定义 字体 

Sto=" 落 起 与 孤 瘤 齐 飞 "…: 

imagettfiext($im,80,0,200,200, $textcolor, Sfont.S$to); / 写 TTF 文字 到 图 中 
S$to=" 秋 水 共 长 天 一 色 "; 

imagettftext($im.80,0,300.400. $textcolor. $font.$to); // 号 TTF 文字 到 图 中 

imagejpeg(S$im); /建立 JPEG 图 形 

imagedestroy($im); 1/ 结束 图 形 ， 释 放 内 存 空间 

ee 

秘笈 心 法 


心 法 领悟 307: 必须 牢记 一 点 ，imagettftext0 函 数 只 支持 utf-8 编码 。 

因为 本 实例 中 页 面 使 用 的 是 utf-8 编码 格式 ， 所 以 在 定义 向 图 片 中 添加 的 中 文字 符 串 时 可 以 直接 使 用 ， 不 需 
要 编码 格式 的 转换 。 但 是 ， 如 果 页 面 本 身 使 用 的 是 gb2312 编码 格式 ， 那 么 就 必须 应 用 iconvO 函 数 对 向 图 片 中 添 
加 的 中 文字 符 串 进 行 编码 格式 的 转换 ， 由 gb2312 编码 转换 为 utf-8 编码 。 
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趣味 指数 : 二 二 二 二 而 ; 


图 实例 说 明 


图 片 是 Web 页 面 最 为 重要 的 组 成 元 素 之 一 ， 新 闻 网 站 、 图 片 资料 网 站 等 备 受 网 民 关 注 的 网 站 每 天 都 会 上 传 
大 量 的 图 片 。 如 果 直 接 将 图 片上 传 到 页 面 中 ， 很 可 能 被 浏览 者 保存 使 用 ， 这 样 站 点 的 版 权 就 不 能 很 好 地 得 到 保 
证 ， 如 果 在 上 传 图 片 过 程 中 ， 动 态 地 为 图 片 添加 水 印 效 果 ， 这 样 不 仅 可 以 对 保证 站 点 版 权 起 到 一 定 作用 ， 如 果 
设计 合理 还 能 有 助 于 网 站 的 推广 。 在 本 实例 中 ， 将 讲解 如 何在 上 传 图 片 的 过 程 中 为 图 片 添加 水 印 文 字 ， 其 运行 
结果 如 图 6.40 所 示 。 


商品 名 称 :3HzP 开 以 由 型 弄 志 大 全 
商品 分 类 。 图 共 -程序 开发 


两 吕 必 存 :20 
DD i 
图 6.40 为 上 传 图 片 添加 文字 水 印 


图 关键 技术 


为 上 传 图 片 添加 水 印 的 重点 是 图 像 处 理 函 数 的 运用 ， 至 于 文件 的 上 传 已 经 在 前 面 的 实例 中 进行 了 详细 的 讲 
解 ， 这 里 就 不 再 著述 。 本 实例 运用 的 关键 技术 如 下 : 

(1) 创建 图 像 函 数 

创建 图 像 函 数 的 运用 是 完成 本 实例 的 第 一 步 ， 因 为 需要 根据 上 传 图 片 的 后 级 (格式 ) 运用 不 同 的 函数 来 创 
建新 图 像 ， 这 里 定义 3 种 格式 的 图 片 (gif、jpg 和 png) ， 所 以 要 应 用 到 3 个 创建 图 像 函 数 ， 分 别 为 : 

imagecreateffromgifO 函 数 ， 根 据 GIF 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标识 符 。 

imagecreatefromjpegO 函 数 ， 根 据 JPG 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标识 符 。 

imagecreatefrompng0 函 数 ， 根 据 PNG 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标识 符 。 

(2) 操作 图 像 函 数 

新 图 像 创建 成 功 后 将 返回 一 个 图 像 标识 符 ， 操 作 图 像 函数 根据 标识 符 对 图 像 进行 操作 ， 这 里 应 用 2 个 函数 : 

imagecolorallocateO 函 数 : 定义 水 印 文字 的 颜色 。 

imagettftext0 函 数 ， 在 返回 的 图 像 中 输入 中 文字 符 串 。 

(3) 输出 图 像 函数 

与 创建 图 像 函 数 对 应 ， 同 样 有 3 个 输出 图 像 函 数 : 

回 imagegifO 函 数 ， 以 GIF 格式 将 图 像 输出 到 浏览 器 或 文件 。 

imagejpegO 函 数 ， 以 JPG 格式 将 图 像 输出 到 浏览 器 或 文件 。 

加 ”imagepng0 函 数 ， 以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 。 

(4) 销毁 图 像 函数 

在 完成 图 像 的 创建 和 输出 之 后 ， 有 必要 销毁 图 像 ， 释 放 与 image 相关 的 内 存 ， 其 应 用 的 是 imagedestroy0 函 
数 ， 语 法 如 下 : 

bool imagedestroy (resource inage ) 

该 函数 释放 与 image 关联 的 内 存 。 参 数 image 是 由 图 像 创 建 函 数 返回 的 图 像 标识 符 。 

在 本 实例 中 ， 要 对 上 述 函 数 进行 整合 应 用 ,创建 AddWaterPress 类 ， 定 义 getExtendsName0 方 法 ， 获 取 上 传 
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图 片 的 文件 后 级 ， 定 义 getImageRes0 方 法 ， 根 据 上 传 文件 的 后 级 创建 新 图 像 ， 定 义 outputImage0 方 法 ， 输 出 图 
像 ， 定 义 add0 方 法 ， 向 指定 的 图 片 中 添加 文字 水 印 。 


力 设计 过 程 


(1) 创建 index.php 文件 。 首 先 ， 创 建 一 个 表单 ， 完 成 上 传 图 片 的 提交 操作 。 然 后 ， 在 本 页 中 输出 存储 在 
服务 器 指定 文件 夹 下 的 图 片 。 最 后 ， 获 取 表单 中 提交 的 图 片 数 据 ， 应 用 move_ uploaded file0 函 数 完成 图 片 的 上 
传 操作 , 并 且 实 例 化 存储 在 AddWaterPress.php 文件 中 的 AddWaterPress 类 , 调用 add0 方 法 为 指定 的 图 片 添加 文 
字 水 印 ， 其 关键 代码 如 下 : 


if(move_uploaded file($ FILES["file"]["tmp_name"], $saveDir)){ /| 执行 文件 上 传 操作 
Tequire_once 'AddWaterPress.php’; // 包 含 添 加 水 印 操作 的 文件 
SaddWaterPress = new AddWaterPress(); /| 类 的 实例 化 


$addWaterPress->add($saveDir, "吉林 省 明日 科技 "); / 拱 行 添加 方法 ， 传 递 参数 ， 指 定 水 印 文字 


echo "<script>alert( 图 片 添加 成 功 ):</script>"; 
(2) 创建 AddWaterPress.php 文件 ， 编 写 AddWaterPress 类 的 内 容 ， 其 关键 代码 如 下 : 


<?php 
class AddWaterPress{ /定义 类 文件 
/省 略 了 部 分 代码 
function add(SimageUrl $watherImageUrbD){ /定义 添加 方法 

Simg = @$this->getImageRes($this->getExtendsName($imageUrl), SimageUrl); /获取 被 操作 的 图 像 标 识 

Stextcolor=imagecolorallocate($img.190,1,23); // 设 置 字体 颜色 为 蓝 色 ， 值 为 RGB 颜色 值 

Sfont="Font/FZHCJW.TTF"; // 定 义 字 体 

imagettftext($img,15,56,20,130,$textcolor, $font,S$watherImageUrl); /号 TIF 文 字 到 图 中 

// 根 据 图 像 标识 符 、 后 组 和 路 径 ， 执 行 outputImage 方法 ， 输 出 图 像 

Sthis->outputImage($img, $this->getExtendsName($imageUrl), SimageUrl); 

imagedestroy(Simg); /销毁 图 像 


} 
} 


力 秘笈 心 法 


心 法 领悟 308: 添加 英文 字符 串 作为 水 印 标记 
本 实例 中 完成 的 是 中 文字 符 串 水 印 标记 的 添加 操作 ， 如 果 要 添加 英文 字符 串 格式 的 水 印 标记 ， 可 以 直接 使 
用 imageString0 函 数 来 完成 ， 其 方法 与 在 图 像 中 输出 英文 字符 串 是 相同 的 。 


图 实例 说 明 
实例 308 介绍 的 是 如 何 为 照片 添加 文字 水 印 , 在 本 实例 中 将 介绍 如 何 为 
上 传 图 片 添加 一 个 图 像 水 印 ， 其 运行 结果 如 图 6.41 所 示 。 


图 关键 技术 


使 用 图 片 作为 水 印 的 前 提 是 这 个 图 片 的 背景 必须 是 透明 的 ， 否 则 输出 的 效果 很 不 理想 。 添 加 图 片 水 印 的 关 
键 是 getimagesize0 和 imagecopy0 函 数 .应 用 getimagesize0 函 数 获 取 上 传 图 片 和 水 印 图 片 的 大 小 ,通过 imagecopy0 
函数 完成 图 片 水 印 的 添加 。 

imagecopy0 函 数 ， 将 图 像 复 制 到 指定 的 另外 一 个 图 像 中 ， 其 语法 如 下 : 

bool imagecopy ( resource dst_im resource src_im int dst_x, int dst_y int sre_x, int sre_y, int src_w,intsrc h ) 

将 图 像 src_im 中 坐标 从 (sre x，sre_ y) 开始 ， 宽 度 为 src_w， 高 度 为 src h 的 一 部 分 复制 到 图 像 dst_ im 中 
坐标 为 〈dst x，dst_y) 的 位 置 上 。 


图 6.41 为 图 片 添加 图 像 水 印 
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在 本 实例 中 , 同样 是 整合 图 像 的 创建 操作、 输出 和 销毁 函数 , 创建 AddWaterPress 类 ,定义 getExtendsName() 
方法 , 获取 上 传 图 片 的 文件 后 绥 ; 定义 getImageRes0 方 法 , 根据 上 传 文件 的 后 缀 创建 新 图 像 : 定义 outputItmage0 
方法 ， 输 出 图 像 ， 定 义 add0 方 法 ， 向 指定 的 图 片 中 添加 图 像 水 印 。 


设计 过 程 
本 实例 的 实现 步骤 与 实例 308 相同 ， 唯 一 的 区 别 是 创建 AddWaterPress php 文件 ， 编 写 AddWaterPress 类 的 


add0 方 法 时 ， 应 用 的 是 getimagesize0 和 imagecopy0 函 数 完成 图 像 水 印 ee 作 。Add0 方 法 的 代码 如 下 : 
function add(SimageUrl, $watherImageUrl, $x, $y){ /定义 添加 
Simg = @$this->getImageRes(Sthis->getExtendsName(SimageUrl), SimageUrD): 人 的 图 像 标识 
Simg1 = @$this->getImageRes($this->getExtendsName($watherImageUrl), SwatherImageUrl): 


S$size = getimagesize($imageUrl); /获取 图 像 大 小 
$sizel = getimagesize($watherImageUrl); /获取 水 印 图 片 的 大 小 
这 $x 一 null && $y—nulD){ / 漳 断 参数 是 否 为 空 
Sxl = (Ssize[0]-Ssizel[0])/2; /根据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 横 坐 标 
Sy1 = (Ssize[1]-Ssizel[1])/2; /根据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 纵 坐 标 
Jelse{ 
Sx1 = Sx; /如 果 不 为 室 ， 则 直接 使 用 坐标 数据 
Syl = $y; /如果 不 为 室 ， 则 直接 使 用 坐标 数据 
imagecopy($img, Simgl, $x1, $y1, 0. 0, $sizel[0], $size1[1]); /将 imgl 的 一 部 分 复制 到 img 的 指定 位 置 
S$this->outputImage(Simg, Sthis->getExtendsName(SimageUrD, SimageUr]); /根据 图 像 标识 符 、 后 级 和 路 径 ， 执 行 outputImage0 方 法 ， 
输出 图 像 
imagedestroy(Simg1): // 稍 毁 图 像 
imagedestroy($img); /销毁 图 像 
秘笈 心 法 


心 法 领悟 309: 使 用 背景 透明 的 图 片 作 为 水 印 图 片 效 果 更 好 。 
在 将 图 片 作 为 水 印 图 像 时 ， 如 果 指 定 的 图 片 背景 不 是 透明 的 ， 那 么 添加 的 水 印 图 像 将 与 原始 图 像 格 格 不 入 
而 如 果 水 印 图 片 的 背景 是 透明 的 ， 那 么 添加 的 水 印 标记 就 可 以 很 好 地 与 原始 图 像 融入 一 体 。 


力 实例 说 明 
验证 码 技术 的 应 用 ， 是 为 了 提高 站 点 的 安全 性 ， 避 免 因 网 页 运行 速度 慢 而 造成 数据 的 重复 提交 。 本 实例 中 ， 
将 通过 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 ， 其 运行 结果 如 图 6.42 所 示 。 


® 从 .合计 的 个 人 博客 


坟 用 F 汪 用 


图 6.42 ”GD2 函数 生成 图 形 验证 码 
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图 关键 技术 


应 用 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 ， 涉 及 的 技术 包括 随机 数 的 生成 、 随 机 数 如 何 传递 
给 图 像 生成 页 、 数 字 图 像 的 生成 以 及 验证 码 的 二 次 生成 。 这 里 重点 介绍 验证 码 图 像 的 生成 。 

(1) 创建 ValidatorCode php 页 面 ， 应 用 GD2 函数 库 中 的 函数 ， 根 据 超 链接 传递 的 参数 值 生成 验证 码 图 像 。 
应 用 的 函数 主要 有 以 下 几 点 : 
imagecreateO) 函 数 ， 创 建 验证 码 图 像 的 画布 ; 
imagecolorallocate0 函 数 ， 定 义 画 布 的 填充 颜色 ; 
imagefill0 函 数 ， 根 据 imagecolorallocate0 函 数 定义 的 颜色 ， 完 成 图 像 颜色 的 填充 操作 ; 
imagestring0 函 数 ， 将 从 超 链接 中 获取 的 验证 码 值 写 入 到 图 像 中 ， 并 且 应 用 imagecolorallocateO 函 数 随 
机 定义 值 输出 的 颜色 ; 

加 ”imagepng0 函 数 ， 生 成 PNG 格式 的 图 像 ; 

加 ”imagedestroy0 函 数 ， 销 毁 图 像 ， 释 放 内 存 。 

(2) 验证 码 的 二 次 生成 。 其 实现 原理 类 似 于 do...while 循环 语句 ， 无 论 条 件 是 否 满足 ， 默 认 都 会 执行 一 次 
(打开 网 页 后 ， 直 接生 成 一 个 验证 码 ) 。 然而， 要 想 使 其 继续 执行 ， 就 必须 满足 指定 的 条 件 (重新 生成 验证 码 ， 
就 必须 调用 指定 的 方法 ) 。 依 据 这 个 原理 ， 在 JavaScript 脚本 中 定义 如 下 方法 : 


因 办 办 加 


function reCodeO{ // 定 义 方法 ， 重 新 生成 验证 码 
var num1=Math.round(Math.random()*10000000); // 生 成 随机 数 

var num=numl.toString0.substr(0.4); /截取 随机 数 
document.codeimg.src="ValidatorCode.php?code="+num; /将 截取 值 传递 到 图 像 处 理 页 中 
forml.defValidatorCode.value=num:; // 将 截取 值 赋 给 表单 中 的 隐藏 域 


} 
在 上 述 方法 中 ， 重 复 执行 JavaScript 脚本 中 默认 的 操作 ， 即 重新 生成 一 个 验证 码 。 
设计 过 程 
(1) 创建 index.php 页 面 ， 定 义 form 表单 ， 设 计 用 户 注册 页 面 的 效果 。 
(2) 编写 JavaScript 脚本 ， 生 成 验证 码 ， 并 定义 reCode0 方 法 ， 用 于 验证 码 的 二 次 生成 ， 其 关键 代码 如 下 : 


‘<script language="javascript"> 

var numl=Math round(Math randomO*10000000); /生成 随机 数 

var num=num1.toString().substr(0,4); /截取 随机 数 的 前 4 个 字符 
document.write("<img name=codeimg src= ValidatorCode php?code="+num+"> /将 值 传递 到 图 像 页 
forml.defValidatorCode.value=num:; // 将 截取 值 赋 给 表单 中 的 隐藏 域 
</script> 


(3) 创建 超 链接 ， 调 用 JavaScript 脚本 中 的 reCode0 方 法 ， 实 现 验证 码 的 二 次 生成 ， 其 代码 如 下 : 
<a href="javascript:reCode0" class="a1"> 看 不 清 </a> 
(4) 创建 ValidatorCode.php 页面 ， 根 据 超 链接 中 传递 的 随机 数 ， 应 用 GD2 函数 生成 验证 码 的 数字 图 像 ， 


其 关键 代码 如 下 : 
<?php 
header('content-type:image/png): /定义 标题 .png 格式 图 像 
S$im = imagecreate(65, 25); /定义 画布 
imagefill($im. 0, 0, imagecolorallocate($im, 200, 200, 200)): /区 域 填充 
SvalidatorCode = S_GET[code]: /获取 提交 的 值 


imagestring(Sim, rand(3, 5), 10. 3, substr($validatorCode. 0. 1). imagecolorallocate($im, 0. rand(0. 255), rand(0, 255))): 
imagestring($im, rand(3, 5). 25, 6. substr($validatorCode. 1. 1). imagecolorallocate($im, rand(0. 255). 0, rand(0. 255))): 
imagestring($im, rand(3, 5). 36, 9. substr($validatorCode. 2. 1). imagecolorallocate($im, rand(0. 255). rand(0. 255). 0)): 
imagestring(Sim. rand(3. 5). 48, 12. substr(SvalidatorCode. 3. 1). imagecolorallocate($im. 0. rand(0. 255), rand(0. 255))); 
imagepng($inn): /生成 PNG 图 像 
imagedestroyO; 1/ 销毁 图 像 
(5) 在 js 文件 夹 下 ， 创 建 一 个 js 脚本 文件 ， 定 义 chkinput0 方 法 ， 对 表单 中 提交 的 注册 信息 进行 验证 ， 包 


括 验证 码 是 否 正 确 。 其 完整 代码 请 参考 本 书 光 盘 。 
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图 秘笈 心 法 


心 法 领悟 310: 生成 带 有 干扰 线 的 数字 图 形 验证 码 。 we 

在 本 实例 中 ， 应 用 GD2 函数 生成 的 是 清晰 的 数字 图 形 验证 码 ， _ 
还 可 以 在 此 基础 上 为 验证 码 增加 干扰 背景 ,使 其 看 上 去 模糊 一 些 , 如 图 643 增加 干扰 背景 后 的 验证 码 图 像 
图 6.43 所 示 。 

其 具体 方法 如 下 : 在 ValidatorCode.php 文件 中 ， 通 过 for 循环 语句 ， 应 用 imagesetpixel0 函 数 在 画布 的 背景 
上 绘制 一 些 单一 元 素 ， 代 码 如 下 : 

for ($i= 0; $i < 200; $i++) { /填充 干扰 背景 

imagesetpixel(Sim, randO % 70, rand0) 96 30, imagecolorallocate($im, rand(0, 255), rand(0. 255), rand(0, 255))); 


实例 311 网 站 月 访问 量 走势 高 级 | 


有 | 


图 实例 说 明 


在 本 实例 中 ， 运 用 GD2 函数 自行 编写 一 个 绘制 折线 图 的 方法 ， 对 2009 年 公司 网 站 的 月 访问 量 进行 分 析 。 


本 实例 中 的 方法 完全 由 笔者 自行 编写 ， 不 借助 于 任何 图 像 的 操作 类 库 ， 其 运行 结果 如 图 6.44 所 示 。 


& 


Jan Feb Harch April Ny June July Pe Sep ov 
i 


图 6.44 GD2 折线 图 分 析 网 站 月 访问 量 走势 
图 关键 技术 
本 实例 中 ， 通 过 GD2 函数 绘制 网 站 访问 量 走势 分 析 图 ， 其 中 涉及 的 关键 技术 如 下 : 


(1) 应 用 imageline0 函 数 绘 制 线条 。 
imageline0 函 数 用 指定 颜色 在 图 像 中 两 点 之 间 绘制 一 条 线段 ， 语 法 如 下 : 


bool imageline ( resource image, int x1, int y1. int x2, int y2. int color ) 

参数 说 明 : 

image: 图 像 标 识 。 

x1: 起 始点 的 横 坐 标 。 

y1: 起 始点 的 纵 坐 标 。 

x2: 结束 点 的 横 坐 标 。 

y2: 结束 点 的 纵 坐 标 。 

color: 颜色 标识 。 

(2) 应 用 百分比 来 显示 数据 信息 ， 并 通过 round0 函 数 将 数字 小 数位 进行 四 舍 五 入 操作 ，round0 函 数 的 语 
法 如 下 : 

double round(double val) 
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参数 var: 进行 四 舍 五 入 操作 的 小 数 。 


图 设计 过 程 


(1) 编写 index.php 文件 ， 创 建 表单 ， 添 加 12 个 表单 元 素 ， 提 交 网 站 的 月 访问 量 数据 。 


(2) 创建 img.php 文件 ， 获 取 表 单 中 提交 的 网 站 月 访问 量 数据 ， 并 对 数据 统计 分 析 。 通 过 GD2 函数 创建 


-个 折线 图 输出 统计 分 析 的 结果 ， 其 关键 代码 如 下 : 


<3php 


$data = array ($_POST ["T1"], $ POST ["T2"], $ POST ["T3"].$_ POST ["T4"], $ POST ["T5"], $ POST ["T6"], $_ POST ["T7"].$_ POST ["T8"], 


$ POST["T9"], $ POST ["T10"], $ POST["T11"],$ POST ["T12"]); 


Smonth = array ("Jan", "Feb", "March", "April". "May" "June". "July", "Aug", "Sep", "Oct", "Nov", "Dec" ); 
Smax =0; 


for($i=0; $i< 12; $i++) { 
Smax = Smax + $data [$i]; 
} 
Sim = imagecreate ( 550, 300 ); 
S$green = imagecolorallocate ( $im, 214, 235, 214 ); 
Sblack = imagecolorallocate ( $im, 0, 0, 0 ); 
Sred = imagecolorallocate ( $im, 255, 0, 0 ); 
Sblue = imagecolorallocate ( $im., 0, 0, 255 ); 
imageline ( $im, 30, 230, 520, 230, Sblue ); 
imageline ( $im, 30, 5, 30, 230, $blue ); 
imagestring ( $im, 3, 520, 222, "X", $black ); 
imagestring ( $im, 3, 16, 1, "Y", $black ); 
$1= 190; 
Skl = 
$k2 = 510; 
for($j =0; < 12; $j +H) { 
imageline ( $im, $k1, $1. Sk2. $1, $black ); 
$1= $1- 40; 


} 

Sf=70; 

S$z1 =20; 

$22 =228; 

for($j =0; $j < 12; 1+) { 
imageline ( $im, Sf $z1, $f, $22, Sblack );: 
Sf= $f+ 40; 


} 

$1= 185; 

for($j = 1; $i < 6; $j ++) { 
imagestring ( $im, 2, 2, $1, 20 * $j . "9%", Sred ); 
$1=$1- 40; 


for($i= 1; $i< 12; $i++H) { 
S$y_lt=$y - (Sdata [$i- 1] / $max) * 200); 
S$y_ht = $y - ($data [$i] / $max) * 200): 


imageline ( Sim., $x * (Si+ 2- 1)+30, $y It Sx * ($i+ 1) * 2- 1)+30, $y_ht. Sred ); 


} 

for($i= 1; $i< 13; $i++) { 
Srl =round ( (($data [$i- 1]) / $max) * 100. 2 ); 
imagestring ( Sim, 2, $x * ($i- 1) + 2+ 40, $y + 11, $month [Si - 1]. $black ): 
imagestring ( $im., 2. $x + (Si - 1) + 2+36., $y + 25. Srl . "9%6", Sred ): 

imagepng ( Sim ); 

imagedestroy ( Sim ); 


图 秘笈 心 法 


心 法 领悟 311: 折线 图 中 数据 的 获取 方式 。 


在 本 实例 中 ， 将 表单 提交 的 数据 直接 作为 折线 图 分 析 的 数据 。 另 外 ， 还 可 以 以 从 数据 库 中 读 取 的 数据 作为 


/所 有 网 站 访问 量 的 累加 和 


/创建 画布 
/设置 颜色 值 


/设置 入 轴 横 坐标 
/设置 站 轴 纵 坐标 
/ 蛤 出 字符 X 
/和 输出 字符 并 


/设置 入 轴 网 格 线 横 坐 标 


/设置 站 轴 网 格 线 纵 坐 标 


/设置 网 站 访问 量 的 纵 坐 标 值 
/获取 每 月 网 站 访问 量 数 的 纵 坐 标 值 
/ 难 制 网 站 访问 量 折线 图 


/输出 月 份 的 值 
/和 葵 出 网 站 访问 量 的 百分比 


/ 拜 放 图 像 资源 


折线 图 分 析 的 数据 ， 其 实现 方法 与 将 数据 库 中 的 数据 输出 到 页 面 中 是 相同 的 。 
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实例 312 赴 味 指数 :机 二 本 而 


图 实例 说 明 多 
在 网 站 中 ， 经 常 需 要 对 相关 的 信息 进行 调查 统计 ， 然 后 根据 访 右 站 
问 者 的 投票 结果 制订 相关 计划 , 为 了 能 够 更 直观 地 查看 访问 者 的 投 区 
票 结果 ， 本 实例 采用 柱 形 图 显示 编程 满意 度 的 投票 结果 ， 其 运行 结 要 | 
果 如 图 6.45 所 示 。 | 国 | “下 


好 色 好 一 般 


x 
图 关键 技术 [二 


通过 GD2 函数 创建 柱 形 图 ， 关 键 是 应 用 imagefilledrectangle0 图 645 GD2 函数 柱 形 图 分 析 编程 词典 
函数 完成 柱 形 图 的 绘制 及 填充 。 满意 度 调查 

imagefilledrectangle0 函 数 ， 在 图 像 中 绘制 一 个 用 指定 颜色 填充 的 矩形 ， 其 语法 如 下 : 

bool imagefilledrectangle ( resource image, int x1, int y1, int x2, int y2, int color ) 

参数 说 明 : 

image: 图 像 资 源 。 

x1: 柱 形 图 左上 角 横 坐标 ; 

yl1: 柱 形 图 左上 角 纵 坐标 ; 

x2: 柱 形 图 右 下 角 横 坐标 ; 

y2: 柱 形 图 右 下 角 纵 坐标 ; 

color: 填充 颜色 。 

在 本 实例 中 , 将 从 数据 库 中 读 取 的 数据 以 柱 形 图 的 形式 进行 展示 ,实现 柱 形 图 与 数据 库 中 数据 的 完美 结合 。 
图 设计 过 程 

(1) 创建 index.php 页 面 ， 编 写 <img> 标 签 输出 img.png 图 像 ， 即 输出 柱 形 图 统计 结果 。 

(2) 创建 img.php 文件 ， 从 数据 库 中 读 取 数据 ， 将 从 数据 库 中 读 取 的 数据 以 柱 形 图 形式 进行 输出 ， 其 关键 
代码 如 下 : 

本 "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 

include ("conn/conn.php"); 

$query = Imysql query ( "select sum(ticket) as total from tb_comment" ); 

Sinfo = mysql fetch array ( $query ); 


Smax = $info [total]; /所 有 投票 的 累加 和 
$sql = mysql_ query ( "select * from tb_comment" ): 

Sresult = mysql_fetch_array ( $sql ); /检索 数据 信息 
S$im = imagecreate ( 350, 300 ): /创建 画布 

S$green = imagecolorallocate ( $im. 233. 240. 151 ): /设置 颜色 值 


Sblack = imagecolorallocate ( $im. 0. 0. 0 ); 
Sred = imagecolorallocate ( $im, 255. 0, 0 ): 
S$blue = imagecolorallocate ( $im, 0, 0. 255 ); 


imageline ( $im, 30, 230. 290. 230. $blue ): /设置 入 轴 横 坐 标 
imageline ( $im, 30, 5. 30. 230. $blue ): /设置 站 轴 纵 坐标 
imagestring ( $im. 3. 295. 222. "X". $black ): /输出 字符 和 

imagestring ( Sim, 3, 16, 1, "Y", Sblack ); /吐出 字符 Y 

$1= 190; 

$k1 = 30: 

Sk2 = 280; 

for($j =0; $j < 5; Sj +1) { 

imageline ( $im, $k1. $1. $k2. $1. $black ): /设置 和 X 轴 网 格 线 横 坐 标 


forGj=0; Sj<45+n)f 


imageline ( $im, $f, $z1, $f, $22, Sblack ): 

Sf= $f+ 50; 

} 

$1= 185; 

for(Sj =1; 8 <6:5 +1) { 

imagestring ( Sim, 2, 2, $1, 20 * $j . "9%", Sred ); 
$1=$1- 40; 


并 ($result [comment] 一 "好 ") { 
Scomment = "好 "; 


》 
寺 ($result [comment] 一 "良好 ") { 
Scomment = "良好"; 


} 
让 (Sresult [comment] 一 "一般") { 
Scomment= "一般"; 


} 
让 (Sresult [comment] 一 " 差 ") { 
Scomment = " 差 "; 


} 

$fnt = "Font/FZHCJW.TTF"; 

$y_ht = round ( ($result [ticket] / $max) * 200, 2 ); 

$y_ht1 = round ( ($result [ticket] / $max) * 100, 2 ); 
imagefilledrectangle ( $im, $x, $y, $x + $x_width, $y - $y_ht, Sred ); 


imagestring ( $im, 2, $x + $x_width - 20, $y - $y_ht - 20, Sy_htl . "%", $black ); 


imageTTFText ( $im, 15, 0, $x + 2. $y + 20. $black, $fnt, $comment ); 
$x += ($x_width + 30); 
ese re mysql_fetch_array ( $sql ) ); 
="『 编程 词典 满意 度 调查 」 投 票 结果 "; 
et 15, 0, 10, $y + 50, $black, $fnt, $text ); 
imagedestroy ( Sim ); 
> 


图 秘笈 心 法 
心 法 领悟 312， 注 意 编码 格式 的 选择 。 


/设置 工 轴 网 格 线 纵 坐 标 


/定义 输出 字体 串 


/定义 输出 字体 串 


/定义 字体 
/设置 投票 结果 所 占 百分比 

// 设 置 投票 结果 所 占 百分比 

/| 颇 制 并 填充 柱 形 图 

// 设 置 投票 结果 所 占 百分比 

/号 TTF 文字 到 图 中 

/设置 两 柱 形 图 之 间 的 宽度 为 30 像素 


/ 写 TIF 文字 到 图 中 
/释放 图 像 资源 


在 本 实例 中 运用 的 是 utf-8 编码 格式 ， 所 以 在 图 像 中 输出 中 文字 符 串 时 可 以 直接 应 用 imageTTFText0 函 数 ; 
但 是 ， 如 果 页 面 使 用 的 是 gb2312 编码 格式 ， 那 么 要 输出 中 文字 符 串 时 ， 就 必须 将 中 文字 符 串 转换 成 utf-8 编码 


格式 ， 否 则 将 输出 乱码 。 


力 实例 说 明 


在 调查 某 类 商品 的 市 场 占有 率 时 ， 最 好 的 显示 方式 就 是 使 用 饼 形 图 ， 通 过 饼 形 图 可 以 直观 地 看 到 某 类 产品 
的 不 同 品牌 在 市 场 中 的 占有 比例 。 运行 本 实例 , 通过 人 饼 形 图 将 不 同 语言 的 软件 图 书 在 市 场 中 的 占有 率 显示 出 来 ， 


运行 结果 如 图 6.46 所 示 。 
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图 6.46 饼 形 图 分 析 软 件 图 书市 场 占有 率 


力 关键 技术 


(1) 绘制 椭圆 弧 线 使 用 GD2 函数 库 中 的 imagefilledarc0 函 数 , 该 函数 在 指定 图 像 标 识 所 代表 的 图 像 中 以 图 
像 左 上 角 为 坐标 点 绘制 一 椭圆 弧 。 如 果 成 功 返回 TRUE， 和 否则 返回 FALSE， 函 数 的 语法 如 下 : 

bool imagefilledarc ( resource image, int cx, int cy, int w, int h, int s, int e, int color int style ) 

参数 说 明 : 

image: 图 像 标 识 。 

cx: 图 像 左 上 角 的 横 坐 标 。 

cy: 图 像 左 上 角 的 纵 坐 标 。 

w: 椭圆 的 宽度 。 

h: 椭圆 的 高 度 。 

s: 以 角度 指定 椭圆 的 起 始点 。 

e: 以 角度 指定 椭圆 的 结束 点 。 

color: 颜色 标识 。 

style: 可 以 是 IMG_ARC PIE、 IMG_ARC _ CHORD、 IMG_ARC_NOFILL、 IMG _ARC _ EDGED 按 位 或 COR) 
后 的 值 .IMG_ARC PIE 和 IMG ARC _CHORD 是 互 斥 的 , IMG_ARC_CHORD 只 是 用 直线 连接 了 起 始 和 结束 点 ， 
IMG ARC _PIE 则 产生 圆 形 边界 (如 果 两 个 都 用 ，IMG_ARC_CHORD 生效 ) ; IMG_ARC NOFILL 指明 弧 或 弦 
只 有 轮廓 ， 不 填充 ，IMG_ARC _EDGED 指明 用 直线 将 起 始 和 结束 点 与 中 心 点 相连 ， 和 IMG_ARC NOFILL 
起 使 用 是 绘制 饼 状 图 轮廓 的 好 方法 (而 不 用 填充 〉。 

(2) 应 用 绘制 柱 形 图 的 方法 ， 通 过 柱 形 图 展示 不 同 颜色 代表 的 数据 。 有 关 柱 形 图 的 应 用 请 参考 实例 312。 

(3) 充分 展示 数据 库 中 数据 与 图 形 结合 的 方法 。 分 别 运 用 for 语句 和 while 语句 对 数据 库 中 的 数据 进行 循 
环 输 出 。 

图 设计 过 程 

(1) 创建 index.php 文件 ， 连 接 数据 库 ， 执 行 查询 语句 ， 获 取 数 据 库 中 总 的 图 书 销量 值 ， 并 通过 <img> 标 签 
调用 图 像 处 理 文件 caky_img .php。 

(2) 创建 caky_img.php 文件 ， 通 过 饼 形 图 和 柱 形 图 联合 分 析 各 语言 图 书 的 市 场 份额 。 首 先 ， 获 取 表 单 中 
传递 的 总 的 图 书 销量 值 ， 并 计算 各 部 门 图 书 销量 值 占 总 图 书 销量 的 比例 。 然 后 ， 根 据 比例 值 创建 饼 形 图 。 最 后 ， 
通过 柱 形 图 输出 不 同 的 颜色 区 块 代表 的 图 书 ， 其 关键 代码 如 下 : 

<?php 


include ("conn/conn.php"); /连接 数据 库 
$query = mysql_query ( "select product_count from tb_data " ); /执行 查询 语句 
Sdata = array 0: /定义 空 数组 
while ( $myrow = mysql fetch array ( $query ) ) { 

Sdata [] = Smyrow [product_count]: /将 查询 结果 写 入 到 数组 中 
} 

Swidths = 580; // 定 义 图 像 宽度 
Sheights = 150: /定义 图 像 高 度 
Swidth = 280; /定义 饼 形 图 宽度 
S$height = 130: /定义 饼 形 图 高 度 
Sangle = array 0: /角度 

Stotal =0; 
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for($i=0:; $i< count ($data ); $i++) { 


if(! is_numeric ( $data [$i] )) // 浏 断 数 组 中 的 值 是 否 为 空 
die ("1"); 

Stotal += $data [$i]:; 
} 
for($i = 0; $i < count ( $data ); Si ++) { 

array_push ( $angle, round ( 360 * $data [$i] / Stotal ) ); // 定 义 饼 形 图 的 角度 值 
} 
Simage = imagecreate ( $widths, $heights ): /创建 饼 形 图 的 画布 
$white = imagecolorallocate ( $image, OxEE, OxEE, OxEE ); /定义 背景 颜色 
S$color = amray (array (imagecolorallocate ( $image, 0x97, 0xbd, Ox00) ); /定义 图 像 的 颜色 值 
Srounds x = $width /2; // 原 线 


for($h = $height /2 + 5; Sh > $height /2- 5; Sh --) { 


); $i < count ( $data ); $i++) { 
= $start+ 0; 
Sstop = $start + Sangle [$i]; 
Scolor i= fimod ( $i, 10); 
imagefilledarc ( $image, $rounds_x, $h, $width, Sheight - 20, $start, $stop, $color [1] [Scolor i], IMG_ARC_PIE ); 
/创建 饼 形 图 


$start += $angle [S$il; 
S$stop += $angle [$i]; 
for($i=0; $i< count ( $data ); $i++) { 
$start = $start + 0: 


$stop = $start + $angle [$i]; 
$color i= fimod ( $i, 10); 
imagefilledarc ( $image, Srounds x, $h, $width, $height - 20, $start, $stop, $color [0] [$color i], IMG_ARC PIE ); 


$start += $angle [$i]; 
$stop += $angle [S$il; 

} 

Sfnt = "FontFZHCJTW.TTF" /定义 字体 

Sm=- 1; 

Sresult = mysql_query ( "select * from tb_data " ); // 读 取 数 据 库 中 存储 的 数据 

while ( $myrow = mysql_fetch_array ( $result ) ) { /iwhile 循环 输出 数据 库 中 数据 
Sm ++: 


imagefilledrectangle ( $image, 295, 15 + 20 + $m, 380, 5 + 20 * $m., $color [0] [$m] ); 。 /给 制 并 填充 柱 形 图 
$comment = $myrow [product_name] . ": ". number format ( $myrow [product_count] /$_GET [counts], 2 ) * 100 . "%"; 
/输出 柱 形 图 
imageTTFText ( $image, 15, 0, 390, 18 + 20 * $m, $color [0] [$m], $fnt, Scomment ); 。 / 写 TTF 文字 到 图 中 
imagepng ( Simage ); 
pe troy ( Simage ); 
(3) 编写 conn 文件 夹 ， 定 义 conn.php 文件 ， 连 接 MySQL 数据 库 服 务 器 ， 连 接 db_database06 数据 库 ， 并 
设置 数据 库 编码 格式 为 utf-8。 
图 秘笈 心 法 
心 法 领悟 313: for 循环 语句 和 while 循环 语句 在 输出 相同 数据 时 的 区 别 。 
同时 应 用 for 循环 语句 和 while 循环 语句 输出 数据 库 中 存储 的 数据 ， 如 果 定 义 变量 $i 的 初始 值 为 0， 那么 在 
for 循环 语句 中 ，$i 的 第 一 个 值 是 0; 而 在 while 循环 语句 中 ，$i 的 第 一 个 值 是 1。 这 就 是 我 们 在 本 实例 中 为 什 
么 将 $m 的 初始 值 设置 为 -1 的 原因 。 只 有 这 样 才能 保证 $m 与 $i 的 值 是 统一 的 ， 以 获取 相同 的 颜色 值 。 如 果 将 $m 
与 $i 的 初始 值 都 设置 为 0， 那么 输出 的 饼 形 图 区 块 的 颜色 将 与 柱 形 图 区 块 的 颜色 不 同 。 
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站 : 关 的 十 : 勾 


采用 PHP 面向 对 象 的 编程 方式 ， 首 先 需要 对 类 进行 定义 。 类 是 对 象 的 模板 ， 所 以 要 定义 规范 、 合 理 的 类 结 
构 首先 应 该 明确 类 应 该 具有 的 属性 和 方法 ， 本 节 将 通过 具体 的 实例 讲解 类 的 定义 方法 。 


实例 314 


力 实例 说 明 
运行 本 实例 ， 如 图 7.1 所 示 。 首 先 在 图 中 的 文本 框 内 输入 连接 MySQL 数据 库 服务 器 所 需 的 必要 参数 ， 然 后 
单 击 “ 连 接 ” 按 钮 即 可 建立 与 指定 的 MySQL 数据 库 服务 器 的 连接 ， 并 将 连接 结果 打印 在 页 面 中 。 
数据 于 连 培 关 的 应 用 
服务 器 地 址 ， Beast 


用 PE 
Cd 


避 
“| 打印 连接 结果 


| 
数据 诗 连 接 喉 功 ! 


图 7.1 数据 库 连 接 成 功 


图 关键 技术 


类 是 对 事物 的 抽象 ， 在 对 类 进行 定义 时 ， 合 理 地 设置 类 的 属性 和 方法 比较 重要 。 例 如 在 本 实例 所 应 用 的 数 
据 库 连接 类 中 ， 将 数据 库 服务 器 地 址 、 数 据 库 服务 器 用 户 名 和 密码 、 数 据 库 名称 以 及 数据 库 字符 集 作 为 类 的 必 
性 保存 ， 而 将 数据 库 连 接 的 实现 过 程 定义 为 类 的 方法 ， 这 是 因为 数据 库 连 接 参数 在 类 的 生命 周期 内 基本 没有 变 
化 ， 而 且 属于 特性 范围 ， 所 以 定义 为 类 的 属性 ， 而 数据 库 连 接 方法 属于 类 的 动作 或 功能 ， 所 以 定义 成 类 的 方法 。 

在 PHP 5.0 以 前 的 版 本 中 ， 类 属性 使 用 关键 字 dim 声明 ， 通 过 该 关键 字 声 明 的 类 属性 可 以 在 类 声明 周期 的 
任何 范围 内 被 调用 。 而 在 PHP5.0 以 后 版 本 中 引入 了 public、protected 和 private 关键 字 来 对 类 中 的 属性 或 方法 进 
行 声明 ， 这 样 根据 不 同 的 关键 字 将 类 的 属性 或 方法 划分 为 公有 成 员 、 保 护 成 员 和 私有 成 员 3 种 ， 其 中 不 同 关键 
字 修饰 的 类 成 员 的 说 明和 区 别 如 下 : 

public， 表 示 该 成 员 可 以 在 任何 范围 被 调用 ， 包 括 类 体内 部 、 该 类 的 子 类 和 类 实例 的 对 象 。 

回 。 protected， 表 示 该 方法 可 以 在 类 中 或 该 类 的 子 类 中 被 调用 。 

加 ”private， 表 示 该 类 只 能 在 类 体内 被 调用 。 


说 明 : 如 果 没 有 对 类 中 方法 指定 任何 访问 权限 ，PHP 会 默认 该 方法 的 访问 权限 为 public。 


图 设计 过 程 

实现 本 实例 ， 首 先 需 要 定义 数据 库 连接 类 ， 然 后 建立 数据 库 参 数 录入 表单 来 指定 数据 库 连接 时 所 需要 的 连 
接 参数 ， 下 面具 体 讲解 该 数据 库 连 接 类 的 设计 和 实现 过 程 。 

(1) 定义 数据 库 连 接 类 , 并 通过 类 的 属性 保存 连接 MySQL 数据 库 所 需 的 参数 , 该 类 的 具体 实现 代码 如 下 : 
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class ConnDb 
Private $host; WMySQL 数据 库 服 务 器 地 址 
private $username; UW 用 户 名 
private $password; /密码 
Private $charset; /| 数据 库 编 码 
Private $dbname; /数据 库 的 名 称 
public function __construct ($host, $username, $password, $dbname, $charset = 'utf-8) /| 构造 方式 实现 类 的 初始 化 
{ 
$this->host = $host; /1 初始 服务 器 地 址 
$this->username = $username; /初始 用 户 名 
S$this->password = $password; /初始 用 户 密码 
$this->dbname = $dbname; 
$this->charset = $charset; /初始 数据 库 字符 集 
} 
public function getConnld (0 /数据库 连接 方法 
{ 
@$connld = mysql_connect($this->host, $this->username, $this->password); /获得 数据 库 连接 句柄 
@mysql_select_db($this->dbname, $connId); 
@mysql_query(set names ' . $this->charset); /设置 字符 集 
Teturn $connld; /返回 连接 句柄 


} 


} 

上 述 代码 中 ， 定 义 了 $host、$username、$password、$charset 和 $dbname 5 个 私有 属性 ， 分 别 用 来 保存 数据 
库 服 务 器 的 主机 地 址 或 名 称 、 数 据 库 服务 器 用 户 名 、 用 户 密码 、 字 符 集 和 要 连接 的 数据 库 名 ， 并 通过 构造 方法 
_ construct0 实 现 数据 库 连 接 参数 的 初始 化 ， 最 后 定义 getConnId( 方 法 返回 数据 库 连 接 句 柄 。 

(2) 建立 数据 库 连 接 参数 录入 表单 ， 该 过 程 通过 HTML 语言 的 表单 标签 实现 ， 具 体 实现 代码 请 详 见 本 书 
附带 光盘 。 

(3) 当 单 击 数据 库 参 数 录 入 表单 中 的 “连接 ”按钮 时 ， 将 会 使 用 如 下 代码 判断 是 否 成 功 连 接 数据 库 : 


iflisset($_POST[host])){ 
require ‘ConnDb.php’; // 包 含 数据 库 连接 类 文件 


$connDb = new ConnDb($_POST['host], $_POST['username'], $ POST['password1], $_POST[dbname'], $_POST[charset]); // 实 例 数据 库 连 接 类 
， echo l$connDb->getConnId0? 数 据 库 连接 失败 ! “数据库 连 接 成 功 ! /打印 连接 结果 
上 述 代码 ， 首 先 通过 isset($_POST[host]) 判 断 用 户 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 使 用 require0 语 句 包含 
数据 库 连接 类 ， 然 后 使 用 new 关键 字 实 例 该 类 ， 并 通过 调用 类 中 的 getConnId( 方 法 来 返回 数据 库 连 接 状 态 ， 最 
后 打印 出 连接 结果 。 


图 秘笈 心 法 


心 法 领悟 314: 用 @ 屏 蔽 运行 期 错误 。 

在 程序 运行 时 ， 有 时 会 难以 避免 地 出 现 运行 期 错误 并 在 页 面 中 打印 错误 信息 ， 这 样 不 仅 会 使 页 面 的 友好 性 
大 打折 扣 ， 而 且 还 会 为 程序 带 来 极 大 安全 隐患 。 使 用 try/catch 语句 可 以 屏蔽 运行 期 错误 ， 不 过 需要 书写 的 代码 
量 相对 较 大 。PHP 提供 了 @ 关 键 字 来 屏蔽 运行 期 错误 ， 只 要 在 可 能 发 生 运行 期 错误 的 代码 前 加 上 “@” 即 可 ， 
例如 本 实例 用 来 屏蔽 连接 数据 库 失 败 时 的 错误 提示 代码 如 下 : 

@$connld = mysql_connect($this->host, $this->username, $this->password); /获得 数据 库 连 接 句 柄 


趣味 指数 : 例会 窗 : 


力 实例 说 明 
使 用 PHP 的 MySQL 函数 库 管 理 MySQL 数据 库 时 ， 首 先 需 要 获得 数据 库 连 接 句 柄 ， 然 后 才能 进一步 进行 
增 、 删 、 改 、 查 操作 。 运 行 本 实例 ， 首 先 在 图 7.2 所 示 的 表单 中 输入 数据 库 连接 参数 ， 然 后 单 击 “ 连 接 ” 按 钮 ， 
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如 果 成 功 连接 上 MySQL 数据 库 则 会 在 页 面 中 打印 出 数据 库 连 接 句柄 。 


字符 集 ; 
| mm 打印 连接 句柄 


数据 库 连 长 成 了 
连接 句柄 为 fesource id #3 


图 7.2 打印 连接 句柄 


图 关键 技术 


在 PHP 面向 对 象 的 编程 方式 中 ， 若 函数 被 定义 在 类 中 ， 就 称 之 为 成 员 方 法 ， 成 员 方法 的 功能 应 该 匹配 该 类 
的 特定 功能 。 

类 中 定义 的 成 员 方法 不 能 出 现 重 名 的 情况 ， 并 且 需 要 注意 以 下 几 点 : 

函数 名 称 不 区 分 大 小 写 ， 如 myfun(0 与 Myfun0 指 的 是 同一 个 函数 。 

加 ”函数 的 参数 没有 限制 ， 可 以 定义 任意 个 需要 的 参数 。 

函数 名 称 理论 上 可 以 使 用 汉字 ， 但 汉字 是 双 字 节 字符 ， 为 了 避免 出 现 无 法 预知 的 问题 ， 尽 量 不 使 用 。 
图 设计 过 程 

(1) 定义 数据 库 连 接 类 ， 在 类 中 定义 数据 库 连接 的 方法 getConnId0， 实 现 该 过 程 的 代码 如 下 所 示 : 


public function getConnId () /其 据 库 连 接 方法 
@$connld = mysql_connect($this->host, $this->username, $this->password); /获得 数据 库 连接 句柄 
@mysql_select_db($this->dbname, $connId); 
@mysql_query (set names ' . $this->charset); /设置 字符 集 
return $connld; /返回 连接 句柄 


} 
在 上 述 方法 中 ,首先 通过 函数 mysql_connect0 获 得 数据 库 连接 句柄 , 然后 使 用 函数 mysql_select_db0 选 择 要 
连接 的 数据 库 ， 并 使 用 函数 mysql_query0 执 行 查询 语句 来 设置 数据 库 的 字符 集 。 


(2) 实例 数据 库 连 接 类 ， 并 打印 连接 句柄 ， 实 现代 码 如 下 所 示 : 
$connDb = new ConnDb($_POSTI[host],$_POST[username],$_POST[password],$_POST[dbname],$_POST[charset]); /实例 数据 库 连接 类 
echo !$connDb->getConnld0? 数 据 库 连接 失败 ! :数据库 连接 成 功 ! <br/> 连 接 句 柄 为 $connDb->getConnId0; /打印 连接 句柄 


力 秘笈 心 法 

心 法 领悟 315: 通过 set names utf8 语句 动态 设置 数据 库 的 字符 集 为 utf-8 编码 。 

在 对 数据 库 内 容 进行 检索 输出 时 ， 有 时 可 能 会 出 现 乱 码 现象 , 一 般 都 是 由 数据 库 字 符 集 设置 存在 偏差 所 致 ， 
为 了 避免 上 述 情况 的 发 生 ， 可 以 在 执行 数据 库 查 询 语句 前 执行 “set names 编码 ”语句 ， 在 开发 项 目 时 ， 为 了 便 
于 国际 化 ， 建 议 应 用 utf-8 编码 。 
< 注意 : 设置 MySQL 数据 库 为 utf-8 编码 所 执行 的 语句 应 该 为 “set names utf8”， 而 非 “set names utf-8”， 

即 “utf” 和 “8” 之 间 没 有 “-”。 
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趣味 指数 : 会 傅 请 
图 实例 说 明 请 输入 一 组 数字 ， 有 要求 用 半角 种 号 分 割 
运行 本 实例 ， 如 图 7.3 所 示 。 首 先 在 图 中 文本 框 中 输入 一 组 数字 并 用 半角 去 2 | 
号 分 割 ， 然 后 单 击 “ 计 算 ” 按 钮 ， 将 在 页 面 中 打印 出 该 组 数字 的 平均 值 。 语 直 数字 平均 和 为 加 
关键 技术 图 7.3 计算 一 组 数 的 平均 值 
实现 本 实例 时 ， 由 于 该 类 只 包含 一 个 用 于 计算 平均 数 的 方法 ， 所 以 在 实现 该 类 时 将 求 平均 数 的 方法 定义 为 


静态 方法 ， 这 样 在 不 实例 该 类 的 情况 下 通过 类 名 即 可 直接 调用 该 方法 。 
在 PHP 面向 对 象 编程 方式 中 ,静态 方法 隶属 于 某 个 类 ， 但 不 受 类 的 束缚 ， 可 以 直接 被 外 部 访问 。 与 定义 类 
中 普通 方法 相 比 ， 定 义 静 态 方法 时 需要 使 用 static 关键 字 进 行 修饰 ， 其 定义 格式 如 下 所 示 : 


public static function 方法 名 0 


/该 方法 实现 的 功能 
在 类 体内 部 调用 该 方法 时 ， 使 用 self 关键 字 加 “::” 调 用 ， 在 类 外 直接 使 用 类 名 加 “::” 引 用 。 
图 设计 过 程 
(1) 建立 数据 统计 类 Stat， 并 在 类 体内 定义 静态 方法 getAvg0 用 来 实现 求 多 个 数字 的 平均 值 ， 其 实现 代码 
a 


a static function getAvg ($arryNum) /定义 静态 方法 来 求 平均 值 
$totalNum = count($arryNum); // 获 得 数字 总 数 
if ($totalNum == 0) { /如果 数 字 个 数 为 0 则 返回 null 
return null; 
}else{ 
$sum = 0; /用 变量 gsum 保存 所 有 数字 的 和 
for ($1 = 0; $i < $totalNum; $i ++) { /通过 循环 计算 所 有 数字 的 和 


$sum += $arryNum[$i]; 
} 
Teturn $sum / $totalNum; /返回 平均 数 


} 

上 述 代 码 用 于 实现 求 平均 数 的 getAvg0 方 法 中 ， 为 了 能 够 实现 求 任意 个 数 数字 的 平均 数 ， 将 数组 作为 参数 ， 
这 样 只 要 求 得 该 数组 所 有 元 素 的 平均 值 即 可 ， 在 具体 实现 过 程 中 ， 首 先 使 用 函数 count0 计 算数 组 元 素 的 个 数 ， 
然后 使 用 for 循环 语句 计算 数组 中 所 有 元 素 的 和 ， 最 后 使 用 return 语句 返回 所 求 得 的 平均 数 。 

(2) 建立 数字 录入 表单 ， 当 用 户 单 击 表单 中 的 “计算 ”按钮 时 ， 将 通过 如 下 代码 计算 在 表单 中 录入 数字 的 


平均 数 : 
iflisset($_POST[nums]) && trim($_POST[nums])!="){ /1 判断 是 否 已 经 提交 表单 
require 'Stat.php'; /包含 数据 统计 类 
S$arrayNum = explode(,,$_POST[nums]); /| 将 提交 数字 保存 到 数组 中 
echo ' 该 组 数字 的 平均 数 为 '. Stat::getAvg($arrayNum); /调用 统计 类 的 静态 方法 getAvg0 求 平均 数 


} 

上 述 代 码 首先 判断 用 户 是 否 提 交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 数据 统计 类 ， 然 后 使 用 函 
数 explode0 用 半角 逗号 分 割 提交 的 数字 字符 串 ， 最 后 调用 数据 统计 类 的 静态 方法 getAvg0 计 算 所 录入 数字 的 平 
均 数 。 
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说 明 : 函数 explode0 用 于 实现 将 字符 囊 以 指定 的 字符 或 子囊 分 割 ， 并 将 分 割 结果 保存 到 数组 中 。 


力 秘笈 心 法 


心 法 领悟 316: 为 了 提高 代码 运行 效率 ， 建 议 将 count0 函 数 放 在 循环 体外 。 
本 实例 计算 数组 中 所 有 元 素 的 和 可 以 有 两 种 写法 ， 分 别 如 下 : 


将 函数 count0 写 在 for 循环 体内 : 
for($i=0; $i<count($arrayNum); $i++){} 


将 函数 count0 写 在 for 循环 体外 : 
$count = count($arrayNum); 
for($i=0; $i<$count; $i++){} 


查看 上 述 两 种 写法 可 知 ， 第 一 种 写法 在 执行 每 次 循环 时 都 需要 执行 一 次 函数 count0， 而 第 二 种 写法 只 在 执 
行 循环 前 执行 一 次 函数 count0 ， 所 以 在 程序 开发 过 程 中 ， 建 议 采 用 第 二 种 写法 ， 可 以 提高 程序 运行 效率 。 


ey 
实 砚 8 趣味 指数 :请 计 坎 


图 实例 说 明 
本 实例 通过 使 用 类 的 方法 重 载 机 制 ， 实 现 不 同类 型 数据 的 运算 。 运 行 本 实例 ， 分 别 如 图 7.4 和 图 7.5 所 示 。 
其 中 ， 图 7.4 展示 的 是 两 个 数值 型 数据 求 和 的 计算 结果 ， 图 7.5 展示 的 是 两 个 字符 串 连接 的 结果 。 


请 输入 要 沈 计 的 内 容 : 请 输入 要 统计 的 和 内容: 
| = | 


统计 缚 果 为 ，3 统计 结果 为， 巨 龙 内 ， 明 旧 升 起 。 
图 7.4 两 个 数字 求 和 的 结果 图 7.5 两 个 字符 串 连接 的 结果 


力 关键 技术 

本 实例 主要 应 用 PHP 面向 对 象 编程 中 的 方法 重 载 实 现 。 通 过 方法 重 载 机 制 ， 可 以 在 子 类 中 定义 与 父 类 同样 
的 方法 ， 然 后 对 该 方法 内 部 功能 代码 进行 重新 编写 ， 这 样 就 实现 了 方法 重 载 。 通 过 方法 重 载 可 以 扩展 或 弥补 原 
父 类 方法 的 缺陷 或 不 足 ， 进 一 步 扩展 类 中 方法 的 功能 。 

例如 ， 已 经 定义 了 较为 复杂 的 汽车 类 Car， 并 在 其 内 部 定义 了 变速 行驶 的 方法 ， 代 码 如 下 : 

class Car 

上 . 


public function changeSpeed() /变速 的 方法 
1 

/实现 手动 变速 的 功能 
} 

/| 其 他 方法 


} 

分 析 上 述 代码 可 知 ， 其 中 的 变速 方法 只 能 实现 “手动 变速 ”的 功能 ， 那 么 如 果 汽车 经 过 改装 可 以 实现 自动 
变速 了 ， 是 不 是 该 Car 类 就 需要 完全 重新 编写 呢 ? 其 实 并 不 需要 这 样 ， 只 要 编写 该 类 的 子 类 ， 然 后 在 子 类 中 重 
写 changeSpeed() 方 法 即 可 ， 实 现 该 过 程 的 示例 代码 如 下 : 

class NewCar extends Car 


让 
站 function changeSpeed( 
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这 条件 D){ 
/实现 手动 变速 的 功能 


jelsef 
/实现 自动 变速 的 功能 
} 


} 
/其 他 方法 
} 


经 过 对 上 述 changeSpeed( 方 法 的 重 写 ， 就 可 以 使 该 方法 既 具 有 手动 变速 又 具有 自动 变速 的 功能 。 从 而 可 以 
缩短 程序 开发 周期 ， 节 约 维护 时 间 。 
图 设计 过 程 

(1) 首先 建立 数据 统计 类 父 类 ， 并 在 该 类 中 定义 统计 方法 execStat0 ， 父 类 所 定义 的 统计 方法 只 有 计算 两 
个 数 和 的 功能 ， 其 实现 代码 如 下 所 示 : 


class StatParent /定义 数据 统计 父 类 
public function execStat ($var0, $varl) /定义 数据 统计 方法 
{ 
return intval($var0 + $varl); /返回 两 个 数 的 和 
} 


(2) 定义 类 Stat， 并 使 该 类 继承 自 StatParent 类 ， 在 该 类 体内 重 写 统计 方法 execStat0， 使 该 方法 根据 传递 
的 参数 类 型 种 类 来 同时 实现 数值 型 的 求 和 及 字符 串 型 的 连接 功能 ， 代 码 如 下 


public function execStat ($var0, $varl) // 重 写 数据 统计 方法 
return is_numeric($var0) && is_numeric($varl) ? intval($var0 + $varl) : Svar0 . $varl; 1/ 如 果 为 数字 则 计算 数字 的 和 ,不 是 数字 则 连 
接 两 个 参数 


} 
} 


了 说 明 : 函数 is_numeric0 用 于 判断 指定 的 内 容 是 否 为 数值 型 数据 或 数值 型 字符 囊 。 


(3) 建立 数据 录入 表单 〈 该 表单 的 实现 代码 请 详 见 本 书 附 带 光 盘 ) ， 当 用 户 在 表单 中 录入 完 要 统计 的 数据 
后 ， 单 击 “ 统 计 ” 按 钮 ， 将 通过 如 下 代码 调用 数据 统计 类 的 execStat0 方 法 对 用 户 提交 的 内 容 进行 统计 : 


iflisset($_POST[txtl]) && $_POST['txt1]!="){ 1 判断 用 户 是 否 提 交 了 表单 
require 'Stat.php'’; /包含 数值 统计 类 
$stat = new Stat0; /实例 数值 统计 类 
echo 统计 结果 为 :'. $stat->execStat($_POST[txtl],$_POST[text2]); /| 输出 统计 结果 
} 
图 秘笈 心 法 


心 法 领悟 317: 使 用 条 件 运算 符 蔡 代 简 单 的 让 条 件 控制 语句 。 


在 编写 程序 时 ， 可 以 使 用 条 件 运算 符 替 代 简单 的 过 条 件 控制 语句 ，PHP 中 条 件 运 算 符 的 使 用 格式 如 下 : 
条 件 表达 式 ? 表 达 式 1: 表 达 式 2 


在 执行 条 件 运算 符 时 ， 首 先 计算 条 件 表 达 式 的 值 ， 如 果 为 真 则 执行 表达 式 1， 反 之 执行 表达 式 2。 


sa 


力 实例 说 明 


本 实例 通过 $this 关键 字 在 汽车 类 内 部 调用 设置 汽车 颜色 的 方法 和 设置 汽车 品牌 的 方法 来 输出 汽车 的 信息 。 


431 


PHP 开发 实战 1200 例 (第 I 卷 ) 


运行 本 实例 ， 如 图 7.6 所 示 ， 分 别 选中 表单 中 的 颜色 和 类 型 单 选 按钮 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打 
印 出 汽车 的 信息 。 


请 达 样 里 色 : 

知 色 : 和 白色，C 黑色 : 会。 宝石 蔓 : 人 
请 选择 类 歼 ， 

青 驰 。 个 ”宝马 全 。 让 连 ， 六 捷达， 六 
| 

我 的 汽车 是 黑色 主 马 


图 7.6 打印 汽车 信息 


图 关键 技术 

在 PHP 面向 对 象 编程 方式 中 ， 可 以 使 用 $this 关键 字 对 类 自身 的 属性 或 方法 进行 调用 。 例 如 已 经 在 A 类 中 
定义 了 方法 fun10， 在 该 类 的 fun20 方 法 中 可 以 使 用 如 下 方式 对 fun10 进 行 调用 : 

class A 


{ 
private function funcl0 


/lfun10 实 现 的 功能 
} 
public function fun2() 
$this->fun10; /调用 fun10 


} 


| | 设计 过 程 


(1) 定义 汽车 类 Car。 首 先 在 该 类 中 定义 汽车 颜色 标识 和 汽车 类 别 标识 两 个 属性 ， 然 后 使 用 构造 函数 对 这 
两 个 属性 进行 初始 化 ， 并 在 类 内 定义 getColor0 方 法 和 getType0 方 法 , 分 别 用 来 获取 汽车 颜色 和 汽车 类 型 ， 最 后 
使 用 getInfo0 方 法 打印 出 汽车 信息 。 本 实例 的 汽车 类 实现 代码 如 下 所 示 : 


class Car /定义 汽车 类 
{ 
private $colorFlag; /| 颜色 标识 
private $typeFlag; /1/ 类 型 标识 
public function __construct ($colorFlag, $typeFlag) /构造 方法 
{ 
S$this->colorFlag = $colorFlag; /颜色 标识 初始 化 
S$this->typeFlag = $typeFlag; /类 型 标识 初始 化 
} 
public function getColor (0) /定义 获取 颜色 方法 
时 
switch ($this->colorFlag) { /使 用 switch 语句 根据 不 用 颜色 获得 标识 和 颜色 
Case 0: 
$color = 红色 ' 
break; 
Case 1: 
$color = ' 白 色 ' 
break; 
case 2: 
$color = 黑色 
break; 
default: 
$color = 宝石 蓝 
Teturn $color: 
} 
public function getType (0 /定义 获得 汽车 类 型 方法 
switch (Sthis->typeFlag) { /根据 类 型 标识 获得 汽车 类 型 
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} 
public function getInfo 0) /获得 汽车 信息 


return ' 我 的 汽车 是 '. $this->getColor0 . $this->getType0; /调用 类 内 方法 返回 汽车 信息 
} 


} 
(2) 建立 汽车 属性 选择 表单 ， 当 用 户 单 击 表单 的 “提交 ”按钮 后 接收 表单 提交 的 颜色 标识 和 类 别 标识 ， 然 
后 使 用 new 关键 字 对 汽车 类 进行 实例 化 ， 最 后 使 用 实例 化 的 汽车 类 的 对 象 调用 该 类 的 getInfo0 方 法 打印 汽车 信 


息 ， 其 代码 如 下 : 

if(isset($_POST['color']) &8& isset($_POST['type]){ /判断 是 否 提 交 了 表单 
require 'Car.php'; // 包 含 汽车 类 
$colorFlag = $_POSTT['color]; /获得 表单 提交 的 颜色 标识 
S$typFlag =$_POST[type]; /获得 表单 提交 的 类 别 标识 
$car = new Car($colorFlag, $typFlag); /对 汽车 类 进行 实例 化 
echo $car->getInfo0); /打印 汽车 信息 

} 

秘笈 心 法 


心 法 领悟 318: 在 类 体内 部 使 用 $this 关键 字 可 以 调用 私有 、 保 护 和 公有 成 员 。 
PHP 面向 对 象 编 程 方式 中 ， 在 类 体内 部 可 以 使 用 $this 关键 字 访问 被 private、protected 和 public 所 修饰 的 属 
性 或 方法 。 


趣味 指数 : 会 会 侠 


实例 319 


实例 说 明 

本 实例 首先 定义 学 生 类 Student， 然 后 在 类 中 分 别 定义 学 习 和 读书 两 个 静态 方法 ， 同 时 在 类 中 定义 非 静 态 的 
getAllMethod( 方 法 ， 通 过 该 方法 使 用 self 关键 字 调 用 学 习 和 读书 这 两 个 静态 方法 ， 在 类 外 分 别 使 用 类 名 和 实例 
的 对 象 调用 类 中 方法 将 输出 如 图 7.7 所 示 的 结果 。 


直接 同 用 类 名 调用 类 的 稳 坊 方法 :学 生 可 以 学 习 、 尽 书 
通过 类 对象 调用 类 中 方法 :学 生 可 以 学 习 、 读 书 


图 7.7 调用 类 中 的 静态 方法 


图 关键 技术 
PHP 面向 对 象 的 编程 方式 中 ， 可 以 使 用 self 关键 字 调 用 类 中 的 静态 属性 或 方法 ， 调 用 格式 分 别 如 下 所 示 : 
class A 
长 
private static $var; /定义 静态 属性 Svar 
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private static function fun0{ /定义 静态 方法 fun() 

} 

public function mainO{ // 定 义 公 有 方法 main0 
self::$var; / 太 | 用 静态 属性 
self::fun(); /| 用 静态 方法 

} 


} 
从 上 述 代 码 可 知 ， 在 类 体内 部 使 用 self 关键 字 加 “::” 引 用 类 中 的 静态 属性 或 静态 方法 。 
< 人 注意 :使 用 self 关键 字 调 用 类 的 静态 属性 时 不 要 遗漏 $, 例如 本 实例 中 的 引用 方法 为 self::$var, 而 非 self::var。 
图 设计 过 程 
(1) 定义 学 生 类 ， 在 类 中 定义 学 生 学 习 的 静态 方法 和 学 生 读 书 的 静态 方法 ， 同 时 定义 非 静 态 方法 
getAllMethod0, 并 在 该 方法 内 部 使 用 self 关键 字 调 用 类 中 的 静态 方法 返回 学 生 可 以 完成 的 活动 , 代码 如 下 所 示 : 


class Student 
: public static function study (0 /定义 学 习 方 法 
return 学 习 ; 
人 static function read (0 /定义 读书 方法 
return 读书 '; 
这 function getAlIMethod 0 /定义 getAlIMethod0 来 获得 类 中 所 有 方法 


return ' 学 生 可 以 '. self::study0 ."、'. self::read0; 


} 
(2) 使 用 require 语句 包含 Student.php 文件 ， 然 后 分 别 使 用 类 名 和 实例 的 对 象 调用 类 中 的 静态 方法 和 
getAllMethod( 方 法 打印 学 生 可 以 进行 的 活动 ， 代 码 如 下 所 示 : 


<?php 
require 'Student.php'; /包含 Student.php 文 件 
?> 


<font color="red"> 
/直接 使 用 类 名 调用 类 的 静态 方法 

学 生 可 以 <?php echo Student::study0?>、<?php echo Student::read0?></font><br/> 
<font color="blue"> 


/通过 类 对 象 调 用 类 中 方法 

<?php 

$student = new Student(; /对 学 生 类 进行 实例 化 

echo $student->getAllIMethod(): // 调 用 学 生 类 的 getAllMethod0 方 法 
?> 


力 秘笈 心 法 


心 法 领悟 319: 使 用 类 名 调用 类 中 静态 方法 ， 将 不 执行 构造 方法 。 
通过 类 名 可 以 直接 调用 类 中 的 静态 方法 ， 那 么 此 时 是 否 会 执行 构造 方法 _construct0 呢 ? 请 看 如 下 代码 : 


class A 
和 public function __construct 0 /| 构造 方法 
echo "构造 方法 '; 
oe static function fun (0 /静态 的 fun0 方 法 
echo fun0'; 
A /通过 类 名 调用 静态 的 fun( 方 法 
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运行 上 述 代 码 将 输出 fun0， 而 没有 输出 构造 方法 中 的 内 容 ， 而 当 使 用 new 关键 字 对 类 进行 实例 化 后 将 执行 
构造 方法 。 


方法 和 颜色 属性 


图 实例 说 明 


本 实例 主要 实现 通过 实例 后 类 的 对 象 调用 类 的 属性 和 方法 。 运行 本 实 。 | Pass _ mewn zs 
例 ， 如 图 7.8 所 示 ， 通 过 调用 汽车 美的 颜色 属性 打印 汽车 颜色 ， 通 过 调用 ee | 
汽车 类 的 条 车 方法 执行 刹车 操作 。 a i 


力 关键 技术 
类 实例 后 的 对 象 不 仅 可 以 调用 类 的 公有 方法 ， 而 且 可 以 调用 类 中 的 公有 属性 ， 其 调用 格式 如 下 : 


$object-> 属 性 ; 
$object-> 方 法 ; 


图 设计 过 程 

(1) 定义 汽车 类 ,在 该 类 中 定义 汽车 颜色 属性 和 汽车 刹车 的 方法 ， 并 通过 构造 方法 对 汽车 颜色 属性 进行 初 
始 化 ， 其 实现 代码 如 下 所 示 : 

class Car 


{ 
public $color; /汽车 颜色 属性 


public function __construct($colon) { /构造 方法 
$this->color = $color; /汽车 颜色 初始 化 
} 


Ppublic function stop0{ /定义 汽车 条 车 方法 
return "汽车 执行 了 刹车 方法 "; 
} 
} 
AY 注意 : 为 了 能 够 在 类 体外 引用 类 的 颜色 属性 ， 需 要 将 颜色 属性 声明 为 公有 属性 。 


(2) 使 用 require 语句 在 index.php 文件 中 包含 Car.php 文件 ， 并 对 汽车 类 进行 实例 化 ， 同 时 指定 汽车 类 
的 颜色 属性 值 为 红色 ， 最 后 使 用 实例 化 的 对 象 通 过 符号 “->” 调 用 汽车 类 的 颜色 属性 和 刹车 方法 ， 代 码 如 下 
所 示 : 


<font color="blue"> 

<?php 

$color = 红色 ': 

$car = new Car($color); 

echo 汽车 的 颜色 为 一 “. $car->color'<br/>': 
echo 行驶 过 程 中 一 “. $car->stop(: 

?> 


力 秘笈 心 法 


心 法 领悟 320: 使 用 $this 引用 类 的 属性 时 ， 请 注意 “$” 的 位 置 。 
引用 类 内 的 属性 时 ，“$” 应 该 放 在 this 前 ， 即 $this->var， 而 非 this->$var。 
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中 级 
趣味 指数 ， 育 请 记 


图 实例 说 明 


本 实例 采用 二 维 数组 模拟 数据 库存 储 学 生 信息 , 然后 通过 for 循环 语句 实例 学 生 类 , 并 通过 构造 方法 为 学 生 
类 的 属性 赋 初 值 ， 最 后 通过 类 的 getXxx0 方 法 获得 学 生 属 性 ， 并 将 学 生 信息 在 页 面 输出 ， 如 图 7.9 所 示 。 


FEED 小 明 四 北京 本 城区 
Er i | ws 北 误 宣 下 区 
EE 民 | 了 六 译注 区 


图 7.9 学 生 信息 列表 


图 关键 技术 


构造 方法 是 类 中 的 一 个 特殊 函数 ， 当 创建 一 个 类 的 实例 时 ， 将 会 自动 调用 类 的 构造 方法 。 在 PHP 5.0 以 前 
的 版 本 中 ， 构造 方法 名 称 与 类 名 相同 ， 而 在 PHP 5.0 以 后 的 版 本 中 统一 使 用 _construct0 作 为 构造 方法 名 称 ， 使 
用 构造 方法 应 该 注意 名 点 : 

回 构造 方法 没有 返回 类 型 和 返回 值 ， 这 是 因为 构造 方法 是 在 创建 对 象 时 自动 调用 的 ， 并 不 是 一 个 独立 

的 函数 ， 因 此 不 需要 返回 值 。 
构造 方法 的 主要 功能 是 实现 对 类 的 初始 化 工作 。 


图 设计 过 程 
(1) 首先 建立 二 维 数组 $students 用 来 模拟 数据 库 ， 代 码 如 下 所 示 : 
$students = array( // 二 维 数组 ， 模 拟 数据 库 


0 => array(0312310', 小明", 16', 北京 西城 区 ) ， 
1 => array(0312311', "小 张 , 16' 北京 宣武 区 ) ， 
2 => array(0312312,， 小 赵 ，17', 北京 海淀 区 ) 
六 
(2) 定义 学 生 类 Student， 在 该 类 中 使 用 构造 方法 _construct0 实 现 对 学 生 信息 的 初始 化 ， 然 后 针对 类 的 各 
个 属性 建立 相应 的 getXxx0 方 法 来 获取 属性 的 值 ， 代 码 如 下 : 


class Student 
1 

private $id; /伴生 ID 
private $name; /| 学 生 名 称 
private $age; /人 学 生年 龄 
private $address; /人 学 生 住址 
public function __construct ($id, $name, $age, $address) /| 构造 方法 ， 对 学 生 信息 初始 化 
{ 

S$this->id = $id; 

$this->name = $name; 

S$this->age = $age; 

S$this->address = $address; 
} 
public function getld 0 /获得 学 生 ID 
机 

Teturn $this->id; 
} 
public function getName () /获得 学 生 名 称 
汉 

Teturn $this->name; 


} 
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public function getAge (0 /获得 学 生年 龄 
Teturn $this->age; 

a function getAddress () /获得 学 生 住址 
return $this->address; 


} 


(3) 通过 for 循环 语句 遍历 保存 学 生 信息 的 $students 数组 ， 遍 历 过 程 中 将 学 生 信息 保存 到 Student 学 生 类 
中 ， 并 通过 该 类 实例 的 对 象 调用 类 中 相应 的 getXxx0 方 法 ， 获 取 学 生 人 信息。 实现 该 过 程 的 代码 如 下 : 


<?php 

Tequire ‘arrayDb.php'; 
require 'Student.php'; 
$count = count($students); 
?> 


<table border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#009933"> 
<tr> 
<td width="100" height="22" bgcolor="#009933"><font color="#FFFFFF"> 学 号 </font></td> 
<td width="100" bgcolor="#009933"><font color="#FFFFFF"> 姓 名 </font></td> 
<td width="100" bgcolor="#009933"><font color="#FFFFFF"> 年 龄 </font></td> 
<td width="200" bgcolor="#009933"><font color="#FFFFFF"> 住 址 </font></td> 
</tr> 
<?php 
for ($i=0; $i<$count; $i++){ 
$stu = $students[$i]; 
$student = new Student($stu[0], $stu[1], $stu[2], $stu[3]); 
?> 
<tr> 
<td height="22" bgcolor="#FFFFFF"><?= $student->getld0?></td> 
<td bgcolor="#FFFFFF"><?= $student->getName(?></td> 
<td bgcolor="#FFFFFF"><?= $student->getAge(?></td> 
<td bgcolor="#FFFFFF"><?= $student->getAddress()?></td> 
</tr> 
<?php 
} 
?> 


图 秘笈 心 法 


心 法 领悟 321: PHP 5.0 中 构造 方法 名 称 以 双 下 划 线 开头 。 
在 使 用 PHP 5.0 的 构造 方法 时 ， 一 定 要 注 


实例 322 


图 实例 说 明 

本 实例 实现 的 功能 是 根据 圆 的 半径 计算 圆 的 面积 ， 运 行 本 实例 ， 如 图 7.10 
所 示 ， 首 先 在 图 中 的 文本 框 内 输入 要 计算 的 圆 面积 的 半径 ， 然 后 单 击 “ 计 算 ” 
按钮 即 可 计算 出 圆 的 面积 ， 并 将 结果 打印 在 页 面 中 。 


图 关键 技术 


本 实例 的 关键 是 通过 类 常量 保存 圆 的 半径 ， 然 后 在 类 的 方法 中 对 该 常量 进行 调用 。 下 面 介 绍 PHP 面向 对 象 


编程 方式 中 类 常量 的 定义 和 引用 方法 。 
大 家 知道 PHP 的 全 局 常量 可 以 使 用 函数 define0 定 义 ， 例 如 : 


意 构 造 方法 “construct0 是 以 双 下 划 线 开头 ， 而 非 单 下 划 线 。 


计算 加 面积; 


消 痊 入 因 的 半径, 下 计划 
读 国 的 本 和 为，12.56 
图 7.10 计算 圆 面积 
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define(PI, '3.17); /定义 常量 ET 
S$radius = 2; /| 指定 圆 半径 
echo ' 圆 面积 为 :". PI * pow($radius, 2); /计算 圆 面积 


在 上 述 代 码 中 首先 使 用 函数 define0 定 义 圆 周 率 常 量 PI， 然 后 指定 圆 半径 为 2， 最 后 在 计算 圆 面积 的 表达 式 
中 调用 常量 PI 计算 圆 面积 。 

而 在 PHP 5.0 以 后 的 面向 对 象 编程 方式 中 ， 引 入 了 类 和 常量 的 概念 ， 类 常量 属于 类 本 身 ， 而 且 区 分 大 小 写 ， 
在 类 体内 与 静态 成 员 类 似 ， 都 使 用 self 关键 字 加 “::” 对 类 常量 进行 引用 ， 例 如 本 实例 所 定义 的 圆 类 中 通过 如 下 
代码 使 用 类 常量 计算 圆 面积 : 


class Circle 
. 
const PI = "3.14"; /定义 圆周 率 为 3.14， 也 可 以 使 用 pi0 函 数 
.省略 部 分 代码 
public function getArea (0 
/获取 圆 面积 


return self::PI * pow($this->radius, 2); 
1 


} 

从 上 述 代 码 可 知 ， 类 常量 使 用 const 关键 字 声 明 ， 与 全 局 常量 类 似 , 习惯 用 大 写字 母 表 示 ， 在 类 的 方法 中 使 
用 self:: 调 用 。 
图 设计 过 程 

(1) 定义 圆 类 ， 首 先 将 圆周 率 保存 在 类 常量 PI 中 ， 然 后 定义 私有 方法 $radius 用 于 保存 圆 的 半径 ， 最 后 定 
义 类 的 公有 方法 getArea0 来 计算 圆 的 面积 ， 实 现代 码 如 下 所 示 : 


class Circle 
{ 
const PI ="3.14"; /定义 圆周 率 为 3.14， 也 可 以 使 用 pi0 函 数 
private $radius; // 圆 半径 
public function __construct ($radius) 
{ 1/ 构造 方法 ， 实 现 对 圆 半径 初始 化 
S$this->radius = $radius; 
public function getArea ( 
{ /获取 圆 面积 


Teturn self::PI * pow($this->radius, 2); 
} 
(2) 建立 圆 半径 录入 表单 〈 该 过 程 的 实现 代码 请 详 见 本 书 附带 光盘 ) ， 在 表单 中 录入 圆 半径 后 ， 单 击 “ 计 
算 ” 按 钮 即 可 计算 圆 面积 并 打印 计算 结果 ， 代 码 如 下 。 


if (tsset($_POST[radius]) && trim($_POST[radius])I="){ /判断 是 否 提交 了 表单 
require_once 'Circle.php'; // 包 含 圆 类 
$circle = new Circle($_POST[radius]); /对 圆 类 进行 实例 化 
echo ' 该 圆 的 面积 为 :'.$circle->getArea0; /打印 计算 结果 
} 
图 秘笈 心 法 


心 法 领悟 322: 使 用 函数 pow0 计 算 指定 数值 的 mn 次 方 寒 。 

在 PHP 编程 中 ， 经 常会 计算 某 个 数 的 mn 次 方 守 ，PHP 提供 了 函数 pow0 用 于 计算 某 个 数 的 m 次 方 寒 ， 该 函 
数 的 语法 格式 如 下 : 

number pow (number base, number exp) 

参数 说 明 : 

base: 要 计算 的 数值 ; 

exp: 圭 数 。 


该 函数 用 于 计算 数值 base 的 exp 次 寡 的 值 ， 如 果 不 能 计算 ， 则 会 发 出 一 条 警告 并 返回 false 值 。 
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7.2 类 的 访问 修饰 符 


在 PHP 5.0 以 前 的 版 本 中 ， 所 有 类 成 员 被 视 为 公有 成 员 ， 即 在 类 体内 、 类 的 子 类 中 以 及 类 实例 后 的 对 象 均 
可 被 调用 ， 而 在 PHP 5.0 以 后 的 版 本 中 ， 引 入 了 私有 成 员 、 保 护 成 员 和 公有 成 员 的 概念 ， 从 而 使 得 PHP 面向 对 
象 的 编程 方式 更 为 成 熟化 。 


实例 323 


图 实例 说 明 


本 实例 用 于 展示 在 类 体外 、 类 内 部 的 方法 中 和 类 的 子 类 中 调用 被 public 关键 字 所 修饰 的 方法 的 结果 ， 如 
图 7.11 所 示 。 


(1) 通 这 沁 车 赤 对 象 吝 用 汽车 类 的 行驶 万 法 的 结果 ; 

行 现 

(2) 通过 汽车 天 的 gstStatus0 方 法 调用 汽车 行驶 万 法 的 结果 : 
汽车 目前 正在 行驶 

(3) 通过 汽车 类 的 子 尖 调用 汽车 类 的 汽车 行驶 方法 的 结 旺 : 
小 汽车 行驶 


图 7.11 被 public 关键 字 修 饰 的 方法 在 不 同 范围 内 被 调用 


图 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 ， 被 关键 字 public 修饰 的 方法 称 为 公有 方法 ， 公 有 方法 可 以 被 类 实例 的 对 象 
在 类 内 部 以 及 类 的 子 类 中 调用 。 


图 设计 过 程 
(1) 首先 建立 汽车 类 Car， 并 在 该 类 内 部 定义 汽车 行驶 方法 run0 以 及 获得 汽车 状态 的 方法 getStatus0 ， 然 
后 定义 类 S SmallCar， 使 该 类 继承 自 类 Car， 并 在 该 类 中 定义 smallCarRun( 方 法 。 实 现 该 过 程 的 代码 如 下 所 示 : 


/定义 汽车 类 Car 

可 public function run () /定义 行驶 方法 

return 行驶 '; 

function getStatus () /定义 返回 汽车 状态 方法 

return 汽车 目前 正在 '. Sthis->run0: 
恩 XANK 类 SmallCar， 并 使 其 继承 汽车 类 Car 
class SmallCar extends Car 
。 public function smallCarRun 0 /定义 小 汽车 行驶 方法 


return ' 小 汽车 '. $this->run0: 
上 
(2) 打印 在 不 同 范围 内 调用 汽车 类 的 行驶 方法 的 结果 ， 代 码 如 下 所 示 : 


439 


PHP 开发 实战 1200 例 (第 I 卷 ) 


require 'Car.php'; 
$car = new Car0: 
echo" (1) 通过 汽车 类 对 象 调用 汽车 类 的 行驶 方法 的 结果 : <br/>'; 
echo $car->runQ) . ‘<br/>"; 
echo ' (2) 通过 汽车 类 的 Sn dl Oh dks <br/>"; 
多 Scar>getStatus0 .” 
M3 妈 过 克基 的 芝 关 调用 汽车 类 的 汽车 行驶 方法 的 结 时: <br>: 
Er new SmallCar(); 
echo $smallCar->smallCarRun0 . ‘<br/>'; 


图 秘笈 心 法 


心 法 领悟 323: 合理 使 用 public 关键 字 修 饰 类 体内 的 方法 。 
在 定义 类 的 时 候 ， 虽 然 使 用 public 关键 字 可 以 使 方法 在 类 的 生命 周期 的 任何 范围 内 被 访问 ， 但 是 不 要 将 类 
中 的 所 有 方法 都 定义 为 公有 ， 这 样 可 以 有 效 提高 程序 的 安全 性 和 商业 化 。 


定义 汽车 的 颜色 属性 中 级 
i 


力 实例 说 明 


本 实例 主要 通过 在 不 同 范围 内 调用 类 中 私有 属性 来 演示 私有 成 员 的 作用 范围 。 运 行 本 实例 ， 如 果 通 过 类 实 
例 后 的 对 象 直接 调用 类 的 私有 属性 ， 将 在 页 面 打 印 如 图 7.12 所 示 的 错误 信息 ， 如 果 通 过 类 中 方法 调用 类 的 私有 
属性 将 输出 汽车 的 颜色 。 


通过 类 实例 的 对 语调 用 类 的 私有 属性 的 结果 ; 


Fatalerrer Cannat necesee prvate proparty Cur'$eolor 在 类 中 的 方 潜 中 调用 类 的 私有 属性 的 结果 : 
in D:\Ayp Servww MRIONO1 ldexplp on ine 17 汽车 题 色 是 : 红色 
图 7.12 通过 对 象 调用 类 中 私有 属性 图 7.13 通过 类 中 方法 调用 类 的 私有 属性 
图 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 , 被 关键 字 private 修饰 的 成 员 称 为 私有 成 员 , 私有 成 员 可 以 在 类 体内 被 调用 ， 
但 不 可 以 被 类 实例 的 对 象 和 类 的 子 类 所 调用 。 
图 设计 过 程 
(1) 首先 定义 汽车 类 Car, 在 汽车 类 中 定义 私有 属性 $color， 并 通过 构造 方法 为 $color 属性 进行 初始 化 ， 最 
后 定义 getColor0 方 法 返回 汽车 颜色 的 值 ， 该 过 程 的 实现 代码 如 下 : 


class Car /定义 汽车 类 Car 
private $color; /汽车 颜色 
public function __construct ($color) /构造 方法 对 类 中 属性 初始 化 
S$this->color = $color: /汽车 颜色 初始 化 
i function getColor (0) /定义 获得 汽车 颜色 的 方法 
return $this->color; /返回 汽车 颜色 


} 


} 
(2) 对 汽车 类 进行 实例 化 ， 并 指定 汽车 颜色 为 红色 ， 然 后 通过 实例 的 对 象 调用 汽车 类 中 的 getColor( 方 法 
获得 汽车 颜色 ， 该 过 程 的 实现 代码 如 下 所 示 。 在 下 述 代码 中 ， 被 注释 的 代码 用 于 实现 通过 类 实例 的 对 象 调用 类 
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中 私有 成 员 的 结果 ， 如 果 去 掉 注 释 将 出 现 如 图 7.12 所 示 的 错误 提示 ， 从 而 说 明 类 中 的 私有 方法 不 能 被 类 实例 的 


对 和 象 所 调用 
i /自任 汽 车 类 
Scolor= 红色 ' /指定 汽车 颜色 
Se /1 对 汽车 类 实例 化 


Wecho ' 通 过 类 实例 的 对 象 调用 类 的 私有 属性 的 结果 : <br/>'; 

Wecho @ 汽 车 颜色 是 : '$car->color.<br/>' or die( 不 能 通过 类 的 对 象 调用 类 中 的 私有 方法 <br/>); 
echo 在 类 中 的 方法 中 调用 类 的 私有 属性 的 结果 : <br>'; 

echo 汽车 颜色 是 : `.$car->getColor0-'<br/>'; /条 印 汽 车 颜色 


图 秘笈 心 法 

心 法 领悟 324: 合理 定义 类 中 的 私有 方法 。 

由 于 私有 成 员 只 可 在 类 体内 被 访问 ， 所 以 在 定义 类 成 员 时 ， 不 准备 在 类 体外 及 该 类 的 子 类 中 引用 的 方法 ， 
应 该 定义 为 私有 方法 。 

如 果 打 算 在 类 体外 获得 某 属性 的 值 ， 建 议 将 该 属性 定义 为 私有 属性 ,然后 再 定义 一 个 公有 的 getXxx0 方 法 ， 
在 该 方法 中 使 用 return 语句 返回 该 属性 的 值 ， 在 类 体外 只 要 通过 类 实例 的 对 象 调用 该 方法 即 可 获得 相应 私有 属 
性 的 值 。 
中 级 


实例 325 趣味 指数 : 窗帘 窗 | 


实例 说 明 

本 实例 主要 用 于 说 明 类 中 的 保护 成 员 在 不 同 范围 内 被 调用 的 结果 。 运 行 本 实例 ， 当 使 用 类 实例 的 对 象 调用 
类 中 的 保护 属性 时 ， 将 出 现 如 图 7.14 所 示 的 错误 提示 ， 然 后 注释 掉 通 过 类 对 象 调用 类 体内 保护 属性 的 代码 ， 并 
分 别 通过 在 类 体内 和 类 的 子 类 中 调用 类 的 保护 属性 ， 再 次 运行 该 实例 ， 将 出 现 如 图 7.15 所 示 的 页 面 。 


通过 类 卖 刚 的 对 象 下 摊 调用 类 中 的 保 访 惧 员 的 结果 


在 类 条 内 记 用 保护 成 员 的 结果 
Fatal emror: Cannot actess froiected Progeny 汽车 加 修 生 限 为 :3 地 

在 类 于 类 中 调用 保护 成 员 的 结 只 
小 汽车 保修 年 限 为 ，5 年 


图 7.14 通过 对 象 调用 类 中 保护 成 员 图 7.15 通过 子 类 调用 父 类 的 保护 成 员 


图 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 ， 被 关键 字 protected 修饰 的 成 员 称 为 保护 成 员 ， 保 护 成 员 可 以 在 类 体内 以 及 
类 的 子 类 中 被 调用 ， 但 不 可 以 在 类 体外 被 调用 。 
图 设计 过 程 

(1) 定义 汽车 类 Car 以 及 该 类 的 子 类 SmallCar。 在 汽车 类 中 定义 汽车 的 保修 时 间 属 性 ， 然 后 使 用 构造 方法 
对 该 属性 进行 初始 化 ， 同 时 定义 获得 汽车 保修 时 间 的 getRepairTime0 方 法 。 在 汽车 类 的 子 类 SmallCar 中 ， 使 用 
构造 方法 调用 其 父 类 的 构造 方法 ， 从 而 实现 对 父 类 的 保修 时 间 属 性 进行 初始 化 ， 最 后 在 SmallCar 类 中 定义 
getSmallCarRepairTime0 方 法 返回 汽车 的 保修 时 间 ， 实 现 该 过 程 的 代码 如 下 : 

class Car 


/定义 汽车 类 Car 
protected $repairTime: /汽车 保修 时 间 属 性 
public function __construct ($repairTime) /构造 方法 对 汽车 的 保修 时 间 进 行 初始 化 
{ 
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S$this->repairTime = $repairTime; 
} 


public function getRepairTime 0 /获得 汽车 保修 时 间 的 方法 
{ 
Teturn $this->repairTime; 
1 
} 
class SmallCar extends Car /定义 汽车 类 的 子 类 SmallCar 


public function __construct ($repairTime) 
{ 


parent::__construct($repair Time); /调用 父 类 构造 方法 对 保修 时 间 属性 进行 初始 化 
} 
public function getSmallCarRepairTime () // 调 用 父 类 的 保修 时 间 属 性 

Teturn $this->repairTime; 


2) 使 用 new 关键 字 对 汽车 类 Car 进行 实例 化 ， 然 后 分 别 打 印 出 在 不 同 范围 内 调用 汽车 类 保护 属性 
$repairTime 的 结果 ， 代 码 如 下 所 示 : 


Cs // 包 全 汽车 类 
S$repairTime = 3; /定义 保修 年 限 
$car = new Car($repairTime); /对 汽车 类 实例 化 


Wlecho 通过 类 实例 的 对 象 直接 调用 类 中 的 保护 成 员 的 结果 <br/>': 

/lecho 汽车 保修 年 限 为 :“.$car->repairTime. 年 <br/>'; 

echo 在 类 体内 调用 保护 成 员 的 结果 <br/>'; 

echo 汽车 保修 年 限 为 ，".$car->getRepairTime0). 年 <br/>'; 

echo 在 类 子 类 中 调用 保护 成 员 的 结果 <br/>"; 

SrepairTime = 5; /定义 保修 年 限 
$smallCar = new SmallCar($repairTime); 

echo 小 汽车 保修 年 限 为 : '$smallCar->getSmallCarRepairTime0). 年 <br/>': 


图 秘笈 心 法 
心 法 领悟 325， 合 理 定义 类 中 的 保护 成 员 。 
如 果 类 中 的 属性 或 方法 ， 只 能 在 类 体 中 或 类 的 子 类 中 被 访问 ， 那 么 建议 将 该 类 定义 为 保护 成 员 。 
7.3 类 的 继承 


继承 性 是 类 的 主要 特点 之 一 ， 通 过 类 的 继承 可 以 扩展 父 类 的 功能 ， 本 节 将 通过 具体 实例 讲解 PHP 5.0 面向 
对 象 编程 方式 中 继承 的 应 用 方法 。 


实例 326 


力 实例 说 明 


本 实例 首先 定义 父 类 水 果 类 ， 并 在 该 类 中 定义 获得 水 果 颜 色 和 水 果 
形状 的 方法 ， 然 后 定义 水 果 类 的 子 类 苹果 类 ， 在 苹果 类 中 只 定义 构造 方 请 给 入 于 风电 区 
法 用 于 实现 对 类 进行 初始 化 ， 然 后 通过 调用 父 类 的 方法 获得 苹果 的 颜色 | 
和 形状 。 rr 条 色 ， 加 的 

运行 本 实例 ， 如 图 7.16 所 示 ， 首 先 在 表单 中 输入 苹果 的 颜色 和 形状 属 ER 
性 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打印 出 苹果 的 颜色 和 形状 属性 。 图 7.16 打印 苹果 颜色 和 形状 属性 
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图 关键 技术 


在 PHP 面向 对 象 编程 方式 中 ， 可 以 使 用 extends 关键 字 继 承 指定 的 父 类 ， 如 下 所 示 : 
class Parentl /定义 父 类 Parentl 


// 父 类 的 成 员 
Child extends Parentl /定义 子 类 Child 
/ 夺 类 的 成 员 
} 
通过 上 述 继承 关系 ， 即 可 在 子 类 中 使 用 parent 关键 字 加 “::” 操 作 符 调用 父 类 的 公有 方法 或 属性 ， 或 者 重 写 
非 final 关键 字 修饰 的 方法 。 
图 设计 过 程 
(1) 定义 水 果 类 Fruit， 在 该 类 中 定义 颜色 属性 $color 和 形状 属性 $shape， 并 通过 构造 方法 对 这 两 个 属性 进 
行 初始 化 ， 然 后 定义 用 于 获得 这 两 个 属性 的 getColor0 方 法 和 getShape0 方 法 ， 代 码 如 下 所 示 : 


class Fruit /定义 水 果 类 
private $color; /颜色 属性 
private $shape; /形状 属性 
public function __construct ($color, $shape) // 构 造 方法 对 水 果 类 初始 化 


{ 
S$this->color = $color; 
$this->shape = $shape; 


i function getColor () // 获 得 水 果 颜 色 
Teturn $this->color; 
a function getShape (0 /获得 水 果 形 状 
return $this->shape; 


} 

(2) 定义 苹果 类 Apple， 使 该 类 继承 自 水 果 类 Fruit， 并 定义 苹果 类 的 构造 方法 ， 在 构造 方法 中 使 用 parent 
关键 字 调 用 父 类 构造 方法 对 父 类 进行 初始 化 ， 代 码 如 下 所 示 : 

class Apple extends Fruit // 苹 果 类 继承 水 果 类 


{ 
public function __construct ($color, $shape) // 构 造 方法 对 类 进行 初始 化 
{ 


parent::_construct($color, $shape); 
} 
} 


(3) 建立 苹果 颜色 和 形状 录入 表单 。 用 户 在 表单 中 输入 苹果 的 颜色 和 形状 后 单 击 “ 提 交 ” 按 钮 ， 将 通过 如 
下 代码 打印 苹果 的 颜色 和 形状 属性 : 


if(isset($_POST[ color’]) && $_POST['color]!="){ /1/ 判 断 是 否 已 经 提交 表单 
require Fruit.php'; // 包 含水 果 类 
$apple = new Apple($_POST[color],$_POST[shape]): /对 水 果 类 进行 实例 化 


echo' ”<font color="blue"> 我 看 见 的 苹果 是 : "$apple->getColor(.'，'".$apple->getShape0. 的 </font>"; /1/ 打 印 苹果 属性 
} 


上 述 代 码 首先 判断 用 户 是 否 已 经 提交 表单 ， 如 果 是 则 首先 使 用 require 语句 包含 苹果 类 , 然后 使 用 new 关键 
字 对 苹果 类 进行 实例 化 ， 最 后 使 用 苹果 类 实例 的 对 象 调用 父 类 中 的 getColor0 方 法 和 getShape0 方 法 ， 打 印 苹果 
的 属性 。 
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图 秘笈 心 法 


心 法 领悟 326: 使 用 final 关键 字 防 止 类 被 继承 。 

本 实例 的 关键 技术 中 已 经 说 明 父 类 中 使 用 final 关键 字 所 修饰 的 方法 不 能 被 重 2 
其 他 类 所 继承 呢 ? 同样 可 以 通过 final 关键 字 来 修饰 ， 如 下 所 示 : 

final class Fruit // 使 用 final 关键 字 修饰 类 

{ 

} 

上 述 的 Fruit 类 被 final 关键 字 所 修饰 ， 这 样 该 类 就 不 能 被 其 他 类 所 继承 。 


图 实例 说 明 

本 实例 主要 使 用 parent 关键 字 在 小 汽车 类 中 调用 汽车 类 的 行驶 方 
法 。 运 行 本 实例 ,如 图 7.17 所 示 ， 分 别 在 页 面 中 打印 出 通过 汽车 类 调用 ' ww 
其 自身 的 行驶 方法 ， 和 其 子 类 小 汽车 类 调用 其 自身 的 行驶 方法 的 结果 。 ”图 717 打印 汽车 和 小 汽车 的 行驶 方法 


图 关键 技术 
在 PHP 5.0 而 向 对 外 的 编程 方式 中 ,使 用 parent 关键 字 加 操作 符 “:” 调 用 父 类 的 方法 ,调用 过 程 如 下 所 示 ， 
父 类 


那么 如 何 使 一 个 类 不 能 被 


[2 
0 


小 汽车 可 以 行 观 


class Parentl / 定 
public function funParent({ /定义 父 类 的 funParent0 方 法 
} 
Child extends Parentl /定义 子 类 
public function funChild0{ /定义 子 类 的 funChild0 方 法 
parent:funParent0: /调用 父 类 的 方法 


} 
使 用 parent 关键 字 不 仅 可 以 调用 父 类 的 普通 方法 , 而 且 可 以 通过 调用 父 类 的 构造 方法 实现 对 父 类 的 初始 化 。 


国 设计 过 程 
(1) 定义 汽车 类 ， 并 在 该 类 中 定义 汽车 的 行驶 方法 ， 代 码 如 下 : 
class Car /定义 汽车 类 
public function run 0 /定义 行驶 方法 
return 行驶 '; 


} 

(2) 定义 小 汽车 类 使 其 继承 自 汽车 类 ， 在 类 体内 定义 smallCarRun0 方 法 ， 并 在 该 方法 中 使 用 parent 关键 
字 调 用 汽车 类 的 run0 方 法 ， 代 码 如 下 : 

class SmallCar extends Car /定义 小 汽车 类 ， 使 之 继承 自 汽车 类 


上 
public function smallCarRun 0 /定义 小 汽车 行驶 方法 


return 小 汽车 可 以 '. parent::run(); 


上 
} 
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(3) 使 用 require 语句 包含 Car.php 文件 ， 然 后 分 别 对 汽车 类 Car 和 小 汽车 类 SmallCar 进行 实例 化 ， 然 后 


分 别 调用 这 两 个 类 的 行驶 方法 ， 代 码 如 下 : 
require 'Car php' // 包 含 汽 车 类 


$car = new Car(); /对 汽车 类 进行 实例 化 

echo $car->run(0 . ‘<br/>'; /调用 汽车 类 行驶 方法 

$smallCar = new SmallCar(); 1/ 实 例 小 汽车 类 

echo $smallCar->smallCarRun(); /调用 小 汽车 类 的 行驶 方法 
力 秘笈 心 法 


心 法 领悟 327: 使 用 parent 关键 字 调用 父 类 的 静态 成 员 。 


在 PHP 5.0 面向 对 象 编程 方式 中 ， 不 仅 可 以 使 用 parent 关键 字 调 用 父 类 的 普通 成 员 ， 而 且 可 以 使 用 parent 
关键 字 加 操作 符 “::” 调 用 父 类 的 静态 成 员 。 


图 实例 说 明 
本 实例 主要 通过 在 蕴 果 类 中 重 写 其 父 类 水 果 类 的 getColor0 it 
方法 来 讲解 如 何 应 用 类 的 重 写 机 制 。 运 行 本 实例 ， 如 图 7.18 所 saeane | 


示 ， 其 中 第 一 行为 通过 水 果 类 调用 其 自身 的 getColor0 方 法 的 输 二 
出 结果 ， 第 二 行为 华 果 类 调用 其 自身 的 getColor( 方 法 的 输出 结 。 图 ”18 重 写 水 果 关 的 getColor0 方 法 的 结果 
果 ， 并 且 该 方法 重 写 了 其 父 类 水 果 类 的 getColor0 方 法 。 


力 关键 技术 


子 类 不 仅 可 以 调用 父 类 的 方法 ， 而 且 可 以 对 指定 的 方法 进行 重 写 , 应 用 重 写 机 制 可 以 扩展 类 中 方法 的 功能 ， 
其 中 实现 对 类 中 方法 重 写 的 代码 示例 如 下 : 


class Parentl / 父 类 Parentl 
public function fun0{ 
// 父 类 的 fun0 方 法 
3 
class Child extends Parentl // 子 类 Child 继承 自 Parentl 
public function fun0{ 
/ 重 写 父 类 的 fun0 方 法 
1 


} 
对 上 述 代 码 中 的 子 类 Child 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 类 中 的 run0 方 法 ， 将 执行 子 类 重 ? 
后 的 run0 方 法 的 功能 而 非 父 类 方法 的 功能 。 
图 设计 过 程 
(1) 定义 水 果 类 Fruit， 并 在 该 类 中 定义 getColor0 方 法 ， 然 后 定义 水 果 类 的 子 类 Apple， 使 该 类 继承 自 水 
果 类 Fruit， 在 苹果 类 Apple 中 重 写 其 父 类 的 getColor0 方 法 ， 实 现 该 过 程 的 代码 如 下 所 示 : 
class Fruit /定义 水 果 类 


public function getColor 0 /获得 水 果 颜 色 
{ 


return 不 同 的 水 果 颜色 不 同 ， 无 法 确定 ': 


照 
烟 


PHP 开发 实战 1200 例 (第 I 卷 ) 


Apple extends Fruit // 莉 果 类 继承 水 果 类 
, private $color; /定义 苹果 颜色 属性 
public function __construct ($color) /构造 方法 对 类 进行 初始 化 
$this >color = $color; 
function getColor 0 /获得 水 果 颜 色 
return 苹果 的 颜色 是 '. $this->color; 
} 


(2) 包含 Fruit.php 文件 ， 然 后 使 用 new 关键 字 对 Fruit 类 进行 实例 化 ， 并 通过 实例 化 的 对 象 调用 该 类 的 
getColor0 方 法 ， 最 后 对 Apple 类 进行 实例 化 ， 并 调用 Apple 类 中 的 getColor( 方 法 打印 苹果 的 颜色 ， 该 过 程 的 实 


现代 码 如 下 所 示 : 
require ‘Fruit.php'; // 包 含 Fruit.php 文 件 
$fruit = new Fruit(); // 对 水 果 类 进行 实例 化 
echo $fruit->getColorQ.'<br/>'; /打印 水 果 类 的 获得 颜色 方法 
$apple = new Apple( 红 色 ); /对 蕴 果 类 进行 实例 化 
echo $apple->getColor0; /打印 苹果 类 的 获得 颜色 方法 
力 秘笈 心 法 


心 法 领悟 328: 通过 子 类 对 象 调用 父 类 中 被 重 写 前 的 方法 。 
通过 子 类 被 实例 的 对 象 可 以 使 用 操作 符 “->” 直 接 调 用 父 类 中 被 重 写 的 方法 ， 那 么 如 果 想 通过 子 类 对 象 调 
用 父 类 中 未 被 子 类 所 重 写 的 方法 该 如 何 实现 呢 ? 可 以 在 子 类 中 定义 一 个 私有 变量 ， 该 变量 用 于 保存 父 类 对 象 ， 
然后 在 子 类 构造 方法 中 对 父 类 进行 实例 化 ， 并 将 实例 化 后 的 对 象 赋 给 该 私有 变量 ， 同 时 在 类 体 中 定义 一 个 
getXxx0 方 法 ， 该 方法 用 于 返回 父 类 被 实例 的 对 象 ， 这 样 在 类 体外 就 可 以 通过 子 类 被 实 们 
方法 ， Liaise Elba li i eld, 实现 该 过 程 的 示例 代码 如 下 : 
/定义 父 


class Parent1l 
public function fun 0) /定义 父 类 的 fun0 方 法 
return ' Parent'; 
} 
class Child extends Parentl /定义 子 类 Child 
private $parent; /定义 私有 成 员 ， 用 于 保存 父 类 对 象 
public function _construct 0 / 子 类 构造 方法 
{ 
S$this->parent = new Parent1 0; // 对 父 类 进行 初始 化 
} 
public function getParent 0 /返回 父 类 对 象 
{ 
return $this->parent: 
public function fun 0) // 重 写 父 类 的 run0 方 法 
Teturn 'Child'; 
1 
$child = new Child0: /对 Child 类 进行 实例 化 
echo $child->getParent0->fun0: /以 链 状 方式 调用 父 类 未 被 重 写 的 run0 方 法 


7.4 抽象 类 和 接口 
抽象 类 是 为 规范 面向 对 象 编程 提供 一 种 方式 ， 不 能 被 实例 化 ， 只 能 被 其 他 类 所 继承 。 接 口 是 为 了 实现 一 种 
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特定 功能 而 预 留 的 类 似 类 的 一 种 类 型 ， 只 允许 定义 常量 和 方法 ， 并 且 这 里 的 方法 没有 任何 功能 实现 。 本 节 将 通 
过 具体 实例 讲解 PHP5 面向 对 象 编程 方式 中 ， 抽 象 类 和 接口 的 应 用 。 


实例 329 


图 实例 说 明 


通过 本 实例 可 以 演示 抽象 类 不 能 被 实例 化 ， 只 能 被 继承 的 特点 。 本 实例 首先 定义 抽象 的 父 类 美食 类 ， 然 后 
定义 该 类 的 子 类 面包 类 ， 最 后 分 别 对 这 两 个 类 进行 实例 化 并 调用 获取 制作 原料 的 方法 。 运 行 本 实例 ， 将 在 页 面 
打印 如 图 7.19 所 示 的 错误 提示 ， 从 错误 提示 可 知 ， 抽 象 类 不 能 被 实例 化 。 

如 果 将 抽象 类 实例 的 代码 注释 掉 ， 再 次 运行 本 实例 ， 将 出 现 如 图 7.20 所 示 的 结果 ， 程 序 可 以 正常 运行 说 明 
抽象 类 可 以 被 继承 。 


Faml emer Cannat inatantiats sbattact elass Feodin 


DaApp Servonrw MOT DL Gudexple on ine 15 制作 面包 的 材料 是 面粉 


7.19 实例 抽象 类 的 错误 提示 图 7.20 调用 抽象 类 的 子 类 的 结果 


力 关键 技术 


抽象 类 与 普通 类 的 区 别 在 于 ， 抽 象 类 不 能 被 实例 化 ， 即 不 能 用 来 创建 对 象 ， 只 能 被 继承 。 抽 象 类 的 定义 方 
法 是 在 class 前 加 关键 字 abstract， 如 下 所 示 : 
GEEGESMYCIEES 
// 类 中 的 属性 和 方法 


} 

如 果 对 抽象 类 进行 实例 化 ， 将 在 页 面 打 印 如 图 7.19 所 示 的 错误 信息 。 
图 设计 过 程 

(1) 定义 抽象 美食 类 Food， 在 该 类 中 定义 $material 属性 ， 并 通过 构造 方法 对 该 属性 进行 初始 化 ， 然 后 定 
义 getMaterial( 方 法 返回 美食 的 烹 制 材料 ， 代 码 如 下 所 示 : 


abstract class Food /美食 类 
. private $material; // 亮 制 材料 
public function __construct ($material) // 父 类 构造 方法 
S$this->material = $material; 
a function getMaterial 0 // 获 得 美食 材料 方法 
return $this->material; 


} 
(2) 定义 面包 类 Bread， 并 使 其 继承 自 美食 类 Food， 然 后 在 该 类 的 构造 方法 中 使 用 parent 关键 字 调用 父 类 
的 构造 方法 实现 对 其 父 类 的 初始 化 ， 该 过 程 的 实现 代码 如 下 所 示 : 
class Bread extends Food /面包 类 继承 美食 类 


攻 
public function __construct ($material) /1 子 类 构造 方法 
{ 


Parent::_construct($material); 
} 
} 
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(3) 使 用 require 语句 在 index.php 中 包含 Food.php 文件 ， 然 后 使 用 new 关键 字 对 Bread 类 进行 初始 化 ,最 
ne getMaterial0 方 法 打印 出 制作 面包 所 需 的 材料 ， 代 码 如 下 所 示 : 


//$food = new Food ($material); 

/lecho $food->getMaterial0.<br/>': 

$bread = new Bread($material); 

echo 制作 面包 的 材料 是 : "$bread->getMaterial0.<br/>"; 


图 秘笈 心 法 


心 法 领悟 329: PHP 面向 对 象 编程 方式 只 能 实现 单 继承 。 
上 文 对 PHP 的 继承 进行 了 介绍 , 但 都 是 单一 继承 , 那么 PHP 能 否 实现 多 继承 呢 ? 可 以 通过 定义 如 下 类 的 相 


互 关系 进行 判断 : 
abstract class A{ 1/ 定义 抽象 类 A 
} 
abstract class B{ /定义 抽象 类 B 
} 
class C extends A, B{ /定义 类 C， 使 其 分 别 继承 自 A 和 B 


让 过 代码 中 ， 首先 定义 抽象 类 A 和 抽象 类 B， 然 后 定义 类 C 使 其 同时 继续 类 A 和 类 B。 运 行 上 述 代 码 ， 将 
在 页 面 打印 如 下 错误 信息 ， 说 明 PHP 目前 是 不 能 实现 多 继承 的 : 
Parse error: syntax error, unexpected ',", expecting '{' in D:\AppServ\Wwww\MR\ON\016\t.php on line 8 


图 实例 说 明 
请 输入 学 生 编 号 ，|[0312315 一 | 
本 实例 主要 介绍 PHP 面向 对 象 编程 中 接口 的 定义 、 应 用 ， 以 及 类 如 何 实现 读 内 入 学 生 各 各， 村 厅 
多 个 接口 。 运 行 本 实例 ， 如 图 7.21 所 示 ， 首 先 在 表单 中 输入 学 生 的 学 号 和 学 生 ee 0512315 姓名 是 ， 小 刘 
姓名 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打印 出 学 生 信息 。 
图 关键 技术 图 7.21 打印 学 生 信息 


本 实例 的 关键 技术 是 如 何 定义 接口 ， 以 及 如 何 实现 一 个 或 多 个 接口 。 在 PHP 中 接口 使 用 关键 字 interface 声 
明 ， 在 类 体内 不 能 有 属性 定义 ， 只 能 有 方法 声明 ， 并 且 不 能 在 方法 中 定义 任何 功能 代码 ，PHP 中 接口 的 定义 方 
法 如 下 所 示 : 

interface name 

public function fun10; 

, private function fun2($param); 

对 接口 定义 完成 后 ， 可 以 在 定义 类 时 使 用 关键 字 implements 来 实现 一 个 或 多 个 接口 ， 所 实现 的 多 个 接口 名 
称 之 间 使 用 逗号 分 割 ， 例 如 : 


class MyClass implements interfacel, interface2, interface3 


/需要 实现 各 个 接口 中 所 声明 的 方法 
} 


综 上 可 知 ， 实 现 接 口 的 类 中 至 少 应 包括 所 实现 接口 中 声明 的 方法 。 
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图 设计 过 程 


(1) 定义 学 生 ID 接口 ， 在 接口 中 声明 用 于 设置 学 生 ID 的 setId0 方 法 和 获得 学 生 ID 的 getId0 方 法 ， 代 码 
如 下 所 示 : 


interface Property_Id /| 编号 接口 
{ 
public function setId ($id); /方法 声明 
public function getId (0; 
} 


(2) 定义 学 生 名 称 接口 Property_Name， 并 在 接口 中 声明 设置 学 生 姓名 的 setName0 方 法 和 获得 学 生 姓名 的 
getName(0 方 法 ， 实 现代 码 如 下 所 示 : 


interface Property Name /名 称 接口 
public function setName ($name); /方法 声明 
public function getName (0; 


(3) 定义 学 生 类 Student， 使 其 同时 实现 Property_Id 接口 和 Property_Name 接口 ， 并 实现 类 中 所 声明 方法 
的 定义 ， 代 码 如 下 : 


class Student implements Property_Id, Property_Name /定义 学 生 类 ， 使 其 同时 实现 Property_Id 和 Property_Name 两 个 接口 
{ 
private $id; /编号 属性 
private $name; /名称 属性 
public function setId ($id) /实现 接口 中 的 各 个 方法 
S$this->id = $id; 
} 
public function getld () 
return $this->id; 
} 
public function setName ($name) 


S$this->name = $name; 
} 
public function getName () 
{ 


Teturn $this->name; 


} 
(4) 建立 学 生 属 性 信息 录入 表单 ， 当 单 击 表单 中 的 “提交 ”按钮 后 ， 将 在 页 面 中 打印 出 所 录入 的 学 生 编 号 
和 学 生 名 称 ， 代 人 码 如 下 : 


if(isset($_POST[id]) && $_POST[id]!="){ // 济 断 是 否 提交 了 表单 
require 'Student.php'; /包含 学 生 类 
$student = new Student(); // 对 学 生 类 进行 实例 化 
$student->setId($_POST[id]); // 设 定 学 生 人 D 
$student->setName($_POST['name']); // 设 定 学 生 名 称 


echo '<font color="green"> 当 前 学 生 的 学 号 是 ，'.$student->getId0.， 姓名 是 : '$student->getName0.'</font> 1/ 打 印 学 生 信息 
} 


上 述 代码 中 ， 首 先 判断 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 Student.php 文件 ,然后 
使 用 new 关键 字 对 学 生 类 Student 进行 实例 化 , 并 调用 实例 化 后 对 象 的 setXxx0 方 法 分 别 为 学 生 编 号 和 学 生 姓名 
赋 初 值 ， 最 后 分 别 调用 类 中 的 getXxx0 方 法 打印 学 生 信息 。 


图 秘笈 心 法 


心 法 领悟 330: require 语句 与 include 语句 的 区 别 。 

require 语句 与 include 语句 的 主要 区 别 有 如 下 两 点 : 

只 要 程序 运行 就 会 将 require 语句 所 包含 的 文件 包含 进来 ， 而 include 语句 则 是 执行 到 该 语句 时 包含 指 
定 的 文件 。 
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如 果 包 含 的 语句 不 存在 ，require 语句 将 给 出 错误 提示 ， 而 include 语句 给 出 警告 。 


7.5 类 的 多 态 


多 态 是 面向 编程 方式 的 重要 特点 之 一 ， 通 过 多 态 可 以 为 类 提供 功能 上 的 多 种 实现 ，PHP 中 可 以 通过 继承 或 
接口 来 实现 类 的 多 态 。 


a 
ee ne ne | 


图 实例 说 明 


本 实例 主要 通过 继承 表现 类 的 多 态 。 在 制作 本 实例 时 ， 首 先 定义 动物 类 RS 
Animal， 然 后 分 别 定义 企鹅 类 Penguin 和 昆虫 类 Insect， 并 在 这 两 个 子 类 中 i 
分 别 重 写 动物 类 的 行走 方法 ， 最 后 通过 这 两 个 子 类 实例 的 对 象 调用 其 自身 的 
行走 方法 ， 将 在 页 面 打印 如 图 7.22 所 示 的 内 容 。 图 7.22 通过 继承 实现 类 的 多 态 


图 关键 技术 

本 实例 的 关键 是 如 何 通过 继承 来 实现 类 的 多 态 。 在 PHP 面向 对 象 编程 中 ， 可 以 首先 定义 一 个 抽象 的 父 类 ， 
然后 再 定义 多 个 子 类 来 继承 该 父 类 ， 在 子 类 中 可 以 通过 方法 重 载 的 方式 重 写 父 类 中 的 功能 ， 这 样 就 实现 了 类 的 
多 态 ， 代 码 如 下 所 示 : 


abstract class Parent /定义 抽象 的 父 类 Parent 
{ 
public function fun 0) /定义 父 类 的 fun0 方 法 
return ' 父 类 fun0 方 法 的 实现 ; 
} 
class Childl extends Parent /定义 子 类 Child1， 使 其 继承 Parent 
{ 
public function fun 0 /在 Childl 中 重 写 Parent 类 中 的 fun0 方 法 
return 'Child1 中 fun0 方 法 的 实现 
} 
} 
class Child2 extends Parent /定义 子 类 Child2， 使 其 继承 Parent 
{ 
public function fun (0 /在 Child2 中 重 写 Parent 类 中 的 fun0 方 法 
return 'Child2 中 fun0 方 法 的 实现 '; 
} 
} 


图 设计 过 程 
(1) 定 义 抽象 的 动物 类 Animal, 并 在 该 类 中 定义 行走 的 方法 walk0, 然后 定义 企鹅 Penguin 和 昆虫 类 Insect， 
使 二 者 分 别 继承 类 Animal， 并 在 这 两 个 类 中 重 写 Animal 类 中 的 walk0 方 法 ， 代 码 如 下 所 示 : 


abstract class Animal /定义 动物 类 
二 
public function walk 0 /定义 动物 类 中 的 行走 方法 
return 动物 能 行走 : 
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Penguin extends Animal /定义 企鹅 类 ， 并 使 其 继承 自动 物 类 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 
return 企鹅 可 以 直立 行走 : 
a /定义 昆虫 类 ， 并 使 其 继承 自动 物 类 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 
return ' 昆 虫 可 以 候 行 '; 
} 


(2) 使 用 require 语句 包含 Animal.php 文件 ， 然 后 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， 并 分 别 调用 这 两 个 
类 中 的 walk0 方 法 ， 代 码 如 下 所 示 : 


require ‘Animal.php’; /包含 Animal.php 文件 
$penguin = new Penguin(); // 对 企 牧 类 进行 实例 化 
echo $penguin->walk(); // 调 用 企鹅 类 的 walk0 方 法 
echo '<br/> 

$insect = new Insect0; // 对 昆虫 类 进行 实例 化 
echo $insect->walk(); 1/ 调用 昆虫 类 的 walk0 方 法 


通过 上 述 实 例 的 运行 结果 可 知 ， 企 鹅 类 和 昆虫 类 虽然 都 重 写 了 父 类 的 walk0 方 法 ， 但 在 页 面 中 的 打印 结果 
却 不 同 ， 这 就 是 通过 继承 实现 类 多 态 的 体现 。 
图 秘笈 心 法 

心 法 领悟 331: 使 用 abstract 关键 字 防 止 类 被 实例 化 。 

在 PHP 面向 对 象 编程 中 , 如 果 所 定义 的 类 只 能 被 其 他 类 继承 ,而 自身 并 不 需要 进行 实例 化 , 可 以 使 用 abstract 
关键 字 将 该 类 声明 为 抽象 类 。 

例如 定义 抽象 类 A， 代 码 如 下 所 示 : 


<?php 

abstract class A{ /定义 抽象 类 A 

} 

new AO0; // 对 类 A 进行 实例 化 

如 果 对 类 A 使 用 new 关键 字 进 行 实 例 化 ， 将 在 页 面 中 打印 如 下 错误 信息 ， 从 而 说 明 抽 象 类 是 不 能 被 实例 
化 的 。 


Fatal error: Cannot instantiate abstract class A in D:\AppServ\www\MR\07\018\t.php on line 5 


: 
ES 中 级 : 
S 可 | : 
实例 332 起 味 指数 : 机 机 页 
图 实例 说 明 
本 实例 主要 介绍 如 何 通过 接口 来 表现 类 的 多 态 性 。 制 作 本 实例 时 ， 首 先 PE 
定义 动物 接口 Animal, 然后 分 别 定义 企鹅 类 和 昆虫 类 来 实现 这 个 接口 ,并 实 Pai 
现 接口 中 所 声明 的 walk0 方 法 ， 运 行 本 实例 ， 如 图 7.23 所 示 。 
图 7.23 通过 接口 实 7 
国 关键 技术 图 7.23 通过 接口 实现 类 的 多 态 
在 继承 中 通过 方法 重 写 方式 可 以 体现 类 的 多 态 性 ， 通 过 接口 的 方式 同样 可 以 体现 类 的 多 态 性 ， 代 码 如 下 
所 示 : 
interface A /定义 接口 A 
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省 


public function fun |; /声明 接口 中 的 fun0 方 法 
1 
class Classl implements A /定义 类 Classl 使 其 实现 接口 A 
沁 

public function fun 0 1/ 实现 接口 A 中 的 fun0 方 法 


return 在 类 Classl 中 实现 接口 A 中 的 fun0 方 法 '; 
和 


人 
public function fun (0 /实现 接口 A 中 的 fun( 方 法 
{ 
return 在 类 Class2 中 实现 接口 A 中 的 fun0 方 法 : 
} 

上 述 代码 中 ， 定义 接口 A， 并 在 接口 中 声明 fun( 方 法 ， 然 后 分 别 定义 类 Classl 和 类 Class2， 使 这 两 个 类 都 
实现 接口 A， 并 实现 接口 A 中 的 fun0 方 法 。 从 示例 代码 中 可 知 ， 类 Classl 和 类 Class2 虽然 都 实现 了 接口 A 中 
所 声明 的 fun0 方 法 ， 但 这 两 个 方法 实现 的 功能 却 不 同 ， 从 而 体现 类 的 多 态 性 。 

图 设计 过 程 


(1) 定义 动物 类 接口 Animal， 并 在 该 接口 中 声明 walk0 方 法 ， 然 后 定义 企鹅 类 Penguin 和 昆虫 类 Insect， 
使 这 两 个 类 分 别 实现 Animal 接口 ， 代 码 如 下 所 示 : 


interface Animal /定义 动物 接口 
public function walk (0; 声明 行走 的 方法 

Penguin implements Animal /定义 企鹅 类 ， 并 使 其 实现 动物 接口 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 


return ' 企 笋 可 以 直立 行走 


} 
class Insect implements Animal /定义 昆虫 类 ， 并 使 其 实现 动物 接口 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 
return "昆虫 可 以 疏 行 ; 


} 
(2) 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调 用 类 中 的 walk0 方 法 ， 代 码 如 下 所 示 : 


require 'Animal.php’; // 包 含 Animal.php 文件 

$penguin = new Penguin(); // 对 企鹅 类 进行 实例 化 

echo $penguin->walk(; /i 调用 企鹅 类 的 walk0 方 法 

echo ‘<br/>" 

$insect = new Insect0; /对 昆虫 类 进行 实例 化 

echo $insect->walk(0; /调用 昆虫 类 的 walk0 方 法 
图 秘笈 心 法 


心 法 领悟 332: 抽象 类 和 接口 的 区 别 。 

在 定义 上 ， 在 抽象 类 中 可 以 对 方法 所 实现 的 功能 进行 具体 定义 ， 而 在 接口 中 只 能 对 方法 进行 声明 ， 不 
能 具体 实现 方法 的 功能 。 

在 用 法 上 ， 继 承 抽象 类 的 子 类 可 以 重 写 父 类 的 方法 ， 或 通过 实例 后 的 对 象 直接 调用 父 类 中 的 方法 ， 而 
实现 接口 的 类 中 ， 必 须 包 含 所 实现 接口 的 所 有 方法 。 
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7.6 常用 关键 字 


在 PHP 面向 对 象 编程 中 ， 有 些 关键 字 是 需要 掌握 的 ， 如 final、static、clone、instanceof 等 ， 本 节 将 通过 具 
体 实例 讲解 这 些 关 键 字 的 使 用 方法 。 


中 级 
趣味 指数 : 从容 窗 


图 实例 说 明 

通过 本 实例 主要 讲解 final 关键 字 的 用 法 。 首 先 定义 水 果 类 Fruit， 然 后 定义 final 型 的 苹果 类 Apple， 使 之 继 
承 自 水 果 类 ， 通 过 Apple 类 即 可 实现 对 苹果 属性 的 设置 。 运 行 本 实例 如 图 7.24 所 示 ， 首 先 在 文本 框 中 输入 苹果 
的 颜色 和 形状 属性 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 即 可 在 页 面 中 打印 出 苹果 的 属性 信息 。 如 果 再 定义 一 个 类 ， 并 使 
之 继承 final 型 的 Apple 类 ， 则 会 在 页 面 中 打印 出 如 图 7.25 所 示 的 错误 提示 信息 。 


Tal error: Class Testmay not 
nhtrit fromfioal class (Appi mn 
DaAppServwwwMRW7020 


Eraitple cn ine 30 


图 7.24 打印 苹果 的 属性 图 7.25 继承 final 型 水 果 类 的 错误 提示 


图 关键 技术 

通过 本 实例 的 运行 结果 可 知 ， 使 用 final 关键 字 修 饰 的 类 只 能 被 实例 化 ,不 能 被 继承 ， 如 果 继承 了 final 型 的 
类 ， 将 在 页 面 中 打印 如 下 错误 提示 : 

Fatal error: Class Test may not inherit from final class (Apple) in D:\AppSerwwwwAMR\O7WO20\Fruitphp on line 30 
图 设计 过 程 

(1) 定义 水 果 类 Fruit， 在 该 类 中 定义 水 果 的 颜色 属性 $color， 并 通过 构造 方法 对 颜色 属性 进行 初始 化 ， 然 
后 定义 获得 颜色 的 getColor0 方 法 ， 代 码 如 下 所 示 : 


class Fruit /定义 水 果 类 
Private $color; /定义 颜色 属性 
public function __construct ($color) /通过 构造 方法 对 颜色 属性 进行 初始 化 
$this->color = $color; 
i function getColor (0) /获得 水 果 颜 色 的 方法 


return $this->color; 
} 
(2) 定义 final 型 的 苹果 类 Apple， 并 使 其 继承 水 果 类 Fruit， 在 水 果 类 中 定义 苹果 的 形状 属性 $shape， 通 过 


构造 方法 对 苹果 类 进行 初始 化 ， 最 后 定义 getShape0 方 法 返回 水 果 的 形状 ， 代 码 如 下 所 示 : 
final class Apple extends Fruit /定义 final 型 的 芋 果 类 ， 使 之 继承 水 果 类 
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private $shape; /定义 形状 属性 
public function __construct ($color, $shape) /构造 函数 
{ 
parent::_construct($color); /调用 父 类 构造 方法 
$this->shape = $shape; // 对 形状 属性 进行 初始 化 
} 
public function getShape (0 /获得 苹果 的 形状 方法 
Teturn $this->shape; 
} 
class Test extends Apple { /定义 一 个 Test 测试 类 ， 使 之 继承 final 形 的 Apple 类 


} 
‘/ 
上 述 代码 中 ， 以 多 行 注释 的 部 分 用 于 测试 被 关键 字 final 修饰 的 类 是 否 可 以 被 继承 。 
(2) 建立 苹果 属性 录入 表单 ， 当 用 户 单 击 表 单 中 的 “提交 ”按钮 后 ， 将 通过 如 下 代码 打印 出 苹果 的 属性 : 
if(isset($_POST['color']) && $_POST['color]!="){ 
require ‘Fruit.php'; 
$apple = new Apple($_POST[color],$_POST[shape]); 
echo '<font color="red"> 苹 果 是 '.$apple->getColor0.$apple->getShape0. 的 </font> 


} 
上 述 代 码 中 ， 首 先 判断 用 户 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 Fruit.php 文件 ， 然 
后 对 蕴 果 类 进行 实例 化 ， 最 后 分 别 通过 getColor0 方 法 和 getShape( 方 法 打印 出 苹果 的 属性 。 


图 秘笈 心 法 

心 法 领悟 333: ep en od ti ane 提交 了 表单 。 

在 实际 项 目 开发 中 ， 经 常 需 要 将 表单 提交 到 当前 页 面 进 行 处 理 ， 而 处 理 表单 所 提交 内 容 的 代码 需要 在 表单 
提交 后 执行 ， 那么 如 何 判断 用 户 已 经 提交 了 表单 呢 ? 在 PHP 中 可 以 通过 函数 isset0 实 现 ， 该 函数 的 语法 格式 如 
下 所 示 : 


bool isset ( mixed var [, mixed var [, ...]] ) 
该 函数 的 参数 为 一 个 变量 列表 ， 如 果 所 指定 的 全 部 变量 都 已 经 设置 值 则 返回 TRUE， 反 之 有 一 个 没有 被 设 
置 值 则 返回 FALSE， 例 如 本 实例 中 通过 如 下 代码 判断 是 否 已 经 提交 了 表单 ; 
iffisset($_POST[Tcolor]) && $_POST['color]!="){ 1 判断 用 户 是 否 已 经 提交 了 表单 
/提交 表单 后 的 处 理 代码 


} 


力 实例 说 明 

本 实例 主要 讲解 PHP 面向 对 象 编程 方式 中 的 static 关键 字 的 用 法 ， 运 行 本 实例 ， 如 图 7.26 所 示 ， 首 先 在 图 
中 的 文本 框 中 输入 要 计算 的 数字 ， 同 时 在 计算 类 型 列表 框 中 选择 计算 类 型 ， 然 后 单 击 “ 求 值 ”按钮 ， 即 可 在 页 
面 中 打印 出 计算 结果 。 这 里 要 注意 ， 在 进行 除 运算 时 ， 如 果 除 数 为 0， 则 应 该 给 出 错误 提示 ， 如 图 7.27 所 示 。 


数值 计算 关 : 数值 计算 器 : 
区 | 
[| 万 一 可 
rm | 下 | 
结果 : 4 结果 : 除数 不 能 为 0 
图 7.26 数值 计算 器 7.27 ”除数 为 0 时 的 提示 信息 
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图 关键 技术 


在 PHP 面向 对 象 编程 方式 中 ， 使 用 static 关键 字 修饰 的 属性 称 为 静态 属性 ， 使 用 static 关键 字 修饰 的 方法 称 
为 静态 方法 ， 通 过 类 实例 的 对 象 可 以 调用 类 中 的 公有 方法 ， 而 静态 成 员 的 特点 是 在 不 对 类 进行 实例 化 的 前 提 下 ， 
直接 通过 类 名 即 可 对 其 进行 调用 ， 其 调用 格式 如 下 所 示 : 
类 名 :: 公 有 静态 成 员 
图 设计 过 程 
(1) 定义 数值 计算 类 Math， 并 在 Math 类 中 定义 用 于 进行 加 、 减 、 乘 、 除 运算 的 静态 方法 ， 在 进行 求 除 运 
算 中 通过 try/catch 语句 进行 除数 为 0 时 的 异常 处 理 ， 实 现 该 过 程 的 代码 如 下 所 示 : 


class Math /定义 数值 计算 类 
public static function add ($numl, $num2) // 相 加 的 方法 
大 
return $numl + $num2; 
} 
public static function sub ($num1, $num2) // 相 减 的 方法 
return $numl - $num2; 
public static function multi ($numl, Snum2) / 相 乘 的 方法 
{ 
Teturn $numl * $num2; 
} 
public static function div ($num1, $num2) // 相 除 的 方法 
{ 
try{ 
if ($num2 == 0) { 1/ 如果 除数 为 0， 则 抛 出 异 党 
throw new Exception( 除 数 不 能 为 0); 
} else{ 
return $numl / $num2; 
} 
} catch (Exception $e) { 
return $e->getMessage(); // 如 果 除 数 为 0， 则 给 出 错误 提示 


} 
1 


} 
(2) 定义 数值 录入 表单 ， 当 在 表单 中 录入 数字 ， 并 单 击 表单 的 “ 求 值 ”按钮 后 ， 将 通过 如 下 代码 计算 出 表 
单 中 所 定义 的 算数 运算 的 结果 


if (isset($_POST[num1']) && trim($_POST[num1"]) {= ") { 1/ 判 断 是 否 提交 了 表单 
require "Math.php'; // 包 含 Math.php 文 件 
$numl = $_POST['num1"]; /获得 提交 的 数字 


$num2 = $_POST[num2]; 
switch ($_POST['type']) { 
case + /进行 加 运算 
$result = Math::add ($num]1, $num2); 
break; 
ek /进行 减 运算 
$result = Math::sub($numl, $num2); 
break; 
case *: /进行 乘 运算 
Sresult = Math::multi($num1, $num2); 
break; 
case /: // 进 行 除 运算 
$result = Math::div($numl, $num2); 
break: 


echo 结果 :“. $result; /| 打印 计算 结果 
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上 述 代码 中 ， 首 先 判断 表单 是 否 已 经 提交 ， 如 果 是 ， 则 使 用 switch 语句 判断 要 进行 计算 的 类 型 ， 然 后 通过 
Math 类 直接 调用 其 中 的 静态 方法 进行 计算 。 
国 秘笈 心 法 

心 法 领悟 334: 直接 通过 类 名 调用 类 中 的 静态 方法 时 不 调用 构造 方法 和 析 构 方法 。 

如 果 直 接 通 过 类 名 调用 类 中 的 静态 方法 ， 而 不 通过 new 关键 字 对 类 进行 实例 化 ， 是 否 也 会 执行 类 中 的 构造 
方法 和 析 构 方法 呢 ? 下 面 定义 如 下 代码 ， 在 下 述 代码 中 ， 定 义 类 Test， 然 后 分 别 在 类 中 定义 构造 方法 、 析 构 方 
法 和 静态 方法 fun0， 最 后 使 用 类 名 直接 调用 静态 方法 fun0。 


class Test /定义 Test 类 
public function __construct 0 
/构造 方法 
echo ' 执 行 构造 方法 <br/>'; 
static public function fun () 
1/ 静态 方法 
echo ' 执 行 静态 方法 '; 
public function __destruct 0 
// 析 构 方法 
echo "执行 析 构 方法 '; 
; 
Test:fun0; /通过 类 名 调用 类 中 静态 方法 


运行 上 述 代码 后 ， 将 在 页 面 中 打印 “执行 静态 方法 ”， 从 运行 结果 可 以 得 知 ， 如 果 通 过 类 名 调用 类 中 的 静 
态 方法 ， 不 调用 构造 方法 和 析 构 方法 。 


力 实例 说 明 


本 实例 主要 讲解 PHP 5.0 面向 对 象 编 程 中 clone 关键 字 的 使 用 方法 ， 运 行 本 实例 ， 分 别 如 图 7.28 和 图 7.29 
所 示 ， 其 中 图 7.28 中 的 输出 结果 是 使 用 clone 关键 字 克 隆 对 象 后 ， 分 别 用 原来 对 象 和 克隆 的 对 象 对 类 中 方法 进 
行 重新 赋值 并 调用 的 结果 ， 而 图 7.29 为 使 用 等 号 赋值 的 方式 来 产生 一 个 新 对 象 后 ， 再 分 别 使 用 新 旧 对 象 实现 对 
类 中 的 方法 进行 调用 的 结果 。 


ET ET 全 
交友 是 灰色 半 的 病名 旦 白 色 
图 7.28 使 用 clone 关键 字 传递 对 象 图 7.29 使 用 等 号 传递 对 象 


图 关键 技术 


在 PHP 5.0 以 后 的 版 本 中 ， 使 用 clone 关键 字 实现 对 对 象 的 克隆 ， 该 关键 字 的 语法 格式 如 下 : 
$obj_new = clone $0obj_old; 


初学 者 可 能 会 问 , 直接 用 等 号 就 可 以 将 当前 对 象 赋 给 一 个 其 他 对 象 , 为 什么 还 要 用 clone 关键 字 ? 这 主要 是 
因为 ， 在 PHP 5.0 中 ， 对 象 被 存储 于 独立 的 结构 Object Store 中 ， 而 不 像 其 他 一 般 变量 存储 于 Zval 中 。 在 Zval 
中 仅 存储 对 象 地 址 的 引用 ， 当 赋值 一 个 变量 或 者 将 一 个 变量 传递 给 一 个 函数 时 ， 就 不 再 复制 数据 了 ， 记 以 对 新 
变量 的 更 改 不 会 影响 原 变量 的 内 容 ， 而 采用 Object Store 存储 对 象 时 ， 使 用 等 号 产生 一 个 新 对 象 后 ， 对 新 对 象 的 
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更 改 会 导致 原 对 象 的 更 改 ， 而 使 用 clone 关键 字 克 隆 对 象 ， 可 避免 这 一 问题 。 
LL 说 明 : 使 用 clone 关键 字 克 隆 一 个 对 象 ， 就 好 比 克隆 一 个 人 ， 打 一 下 新 克隆 出 的 人 ， 被 克隆 的 人 并 不 会 感 


到 疼痛 ， 其 中 的 道理 是 一 样 的 。 


图 设计 过 程 


(1) 建立 羊 类 Sheep， 在 该 类 中 定义 羊 的 颜色 属性 $color， 同 时 定义 用 来 设置 颜色 的 setColor0 方 法 和 获得 


颜色 的 getColor0 方 法 ， 代 码 如 下 所 示 : 
class Sheep 
{ 
Private $color; 
public function setColor ($color) 


S$this->color = $color; 
public function getColor 0 


return 羊 的 颜色 是 $this->color; 
3 


/颜色 属性 
/设置 颜色 的 方法 


/获得 颜色 的 方法 


(2) 对 Sheep 类 进行 实例 化 ， 然 后 分 别 用 等 号 赋值 和 用 clone 方法 测试 对 对 和 象 进行 更 改 的 影响 结果 ， 代 码 


require 'Sheep.php'; 
$sheep = new Sheep(); 

的 

$sheep->setColor( 白 色 ); 
echo $sheep->getColor(); 
S$sheepl = $sheep; 

echo ‘<br/>'; 
$sheep1->setColor( 灰 色 ); 
echo $sheep->getColor(); 
如 


$sheep->setColor( 白 色 ); 
echo $sheep->getColor(); 
$sheepl = clone $sheep; 
echo ‘<br/>"; 
$sheep1->setColor( 灰 色 '); 
echo $sheep->getColor(); 


图 秘笈 心 法 


心 法 领悟 335: 克隆 对 象 的 比较 方法 。 


/包含 Sheep.php 文件 
/对 Sheep 类 进行 实例 化 


/设置 羊 的 颜色 
/打印 羊 的 颜色 
/将 S$sheep 对 象 赋值 给 新 对 象 $sheep1 


/通过 新 对 象 gsheepl 调用 设置 颜色 的 方法 
/打印 羊 的 颜色 


/设置 羊 的 颜色 
/打印 羊 的 颜色 
/克隆 $sheep 对 象 ， 产 生 一 个 新 的 $sheep1 对 象 


/通过 新 克隆 的 $sheep1 对 象 调用 Sheep 类 中 的 setColor0 方 法 
/打印 羊 的 颜色 


在 PHP 中 可 以 使 用 “==” 和 “===” 操 作 符 实现 对 对 象 的 比较 ， 为 了 明确 这 两 种 操作 符 的 差别 ， 首 先 看 下 


面 的 例子 。 


class Test 
1/ 类 体 


} 
S$test = new Test(); 
S$test] = clone $test; 


echo intval(($test == $test1)) . ‘<br/>" . intval((Stest 一 = $test])); 


/定义 Test 类 


/对 Test 类 进 实例 化 
/克隆 一 个 新 的 Stestl 对 象 
/打印 比较 结果 


运行 上 述 代码 ， 将 在 页 面 中 打印 1 和 0。 原 因 就 是 在 对 象 比较 时 ，“==” 比 较 两 个 对 象 的 内 容 ， 而 “===” 
则 比较 两 个 对 象 的 句柄 ， 所 以 “ $test==$test1 ”比较 的 是 两 个 对 象 的 内 容 ， 返 回 结果 应 该 为 TRUE， 而 
“$test===$test1” 则 比较 两 个 对 象 的 句柄 ， 即 引用 地 址 ， 所 以 返回 FALSE。 
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中 级 | 
趣味 指数 : 走 二 二 
图 实例 说 明 
本 实例 主要 讲解 PHP 面向 对 象 编程 中 ，instanceof 关键 字 的 使 用 a 
方法 。 运 行 本 实例 ， 将 在 页 面 中 打印 出 如 图 7.30 所 示 的 结果 。 本 实 村 


例 主要 定义 了 苹果 类 和 村 子 类 ,然后 分 别 对 这 两 个 类 进行 实例 化 , 同 
时 定义 一 个 根据 传递 的 对 象 自动 识别 对 象 所 属 类 的 方法 。 


关键 技术 


instanceof 关键 字 用 于 检测 某 实例 是 否 属于 某 一 个 类 的 类 型 ， 如 果 是 ， 则 返回 TRUE， 反之 返回 FALSE， 该 
关键 字 的 使 用 格式 如 下 : 

对 象 名 instanceof 类 名 
图 设计 过 程 

(1) 定义 苹果 类 Apple 和 桔子 类 Orange， 然 后 分 别 在 这 两 个 类 中 定义 获得 颜色 的 方法 getColor0， 代 码 如 


下 所 示 : 
class Apple /定义 苹果 类 


public function getColor (0) // 获 得 苹果 颜色 的 方法 
1 


图 7.30 根据 不 同 的 对 象 调用 类 中 的 方法 


return ' 红 色 '; 
和 } 
class Orange /定义 桔子 类 


public function getColor (0) /获得 桔子 颜色 的 方法 
{ 
return 橙色 '; 
} 
(2) 使 用 require 语句 包含 Fruit.php 文件 ， 然 后 定义 根据 对 象 打印 水 果 颜 色 的 方法 ， 最 后 使 用 new 关键 字 
分 别 对 Apple 类 和 Orange 类 进行 实例 化 ， 并 使 用 getColor0 方 法 打印 出 相应 水 果 的 颜色 ， 代 码 如 下 所 示 : 
require Fruit.php'; // 包 含水 果 类 


function getColor ($obj) /定义 根据 对 象 类 型 获得 相应 水 果 颜 色 的 方法 
{ 
if ($obj instanceof Apple) { 1/ 判 断 是否 为 苹果 实例 的 对 象 
$str = 苹果 是 : 
} elseif (Sobj instanceof Orange) { // 济 断 是 否 为 桔子 实例 的 对 象 
$str = 桔子 是 : 
} 
return $str . $0bj->getColor(; /打印 结果 
} 
$apple = new Apple0: // 对 苹果 类 进行 实例 化 
S$orange = new Orange(); // 对 桔子 类 进行 实例 化 
echo getColor($apple) .'<br/>': /打印 苹果 颜色 
echo getColor($orange); /打印 桔子 颜色 
图 秘笈 心 法 


心 法 领悟 336: 使 用 函数 is_a0 判 断 指定 的 对 象 是 否 属于 某 类 或 其 子 类 的 对 象 。 
从 本 实例 可 知 ， 使 用 instanceof 关键 字 可 以 检测 指定 的 对 象 是 否 属于 某 一 个 类 的 类 型 ， 而 PHP 中 又 提供 了 
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函数 is_a0， 该 函数 用 于 判断 指定 的 对 象 是 否 属于 某 类 或 其 子 类 的 对 象 ， 其 语法 格式 如 下 : 


bool is_a (object object, string class_name ) 
如 果 对 象 object 是 class_name 所 代表 类 或 父 类 的 对 象 则 返回 TRUE， 否 则 返回 FALSE。 


7.7 魔术 方法 


PHP 5.0 中 ， 主 要 提供 了 __set0)、_ get0、__isset0、_unset0、_ clone0、_ toString0 和 _ autoload0 等 魔术 
方法 ， 本 节 将 通过 具体 实例 讲解 PHP 中 魔术 方法 的 含义 和 具体 使 用 方法 。 
中 未 声明 的 属性 赋值 中 级 


趣味 指数 : 会 宣 例 


实例 337 


图 实例 说 明 
本 实例 主要 讲解 如 何 使 用 PHP 中 的 _ set( 方 法 存 取 类 中 未 声明 的 属性 。 运行 本 实例 如 图 7.31 所 示 ， 在 页 面 
中 以 表格 的 形式 列 出 各 本 图 书 的 详细 信息 ， 其 中 图 书 的 “备注 ”属性 使 用 _ set( 方 法 赋值 。 


蔬 名 本 和 者 将 备 注 
PHP 从 基础 到 **》 EE 3 备注 
APHF 函 次" a0 0 各 注 
《PHP 范 网" 700 > 35 备注 
PHP 实 战 **》 719 小 堵 、 沾 刘 加 备注 


图 7.31 图 书信 息 列表 
图 关键 技术 
魔术 方法 _set0 的 作用 是 存 取 类 中 未 声明 的 属性 ， 该 方法 必须 接收 两 个 参数 ， 分 别 用 来 表示 类 中 未 声明 的 
属性 名 和 属性 值 ，_set0 方 法 的 语法 格式 如 下 : 


function __set($name, $value) 
// 可 以 使 用 $name 和 $value 在 方法 中 存 取 类 中 未 定义 的 属性 名 和 数值 


} 
上 述 _set0 方 法 中 的 参数 $name 表示 类 中 未 声明 属性 的 名 称 ，$value 表示 类 中 未 声明 属性 的 值 。 
力 设计 过 程 
(1) 定义 图 书 类 Book, 在 类 中 定义 图 书 的 名 称 、 页 码 、 作 者 和 价格 等 属性 , 并 分 别 定义 这 些 属性 的 setXxx0 
和 getXxx0 方 法 , 然后 在 类 中 声明 _set0 方 法 , 使 用 该 方法 为 类 中 未 声明 的 属性 赋 初 值 , 实现 该 过 程 的 代码 如 下 : 
class Book 


/定义 图 书 类 
二 

private $name; / 书 名 
private $page; /页 码 
private $writer; /作者 
private $price; /价格 
private $other; /其 他 信息 
public function setName ($name) /设置 书 名 
{ 

S$this->name = $name; 
1 
public function getName () /获得 书 名 
{ 

Teturn $this->name; 
} 
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public function setPage ($page) 
Sthis->page = $page; 


public function getPage 0) 
{ 


} 
public function setWriter ($writer) 
{ 


return $this->page; 


S$this->writer = $writer; 
public function getWriter 0 
: Teturn $this->writer; 
function setPrice ($price) 
{ $this->price = $price; 
public function getPrice (0 


Teturn $this->price; 


} 
public function __set ($name, $value) 
{ 


S$this->other = $value; 


} 
public function getOther (0 
{ 

Teturn $this->other; 
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/设置 页 码 


/设置 作者 


/设置 价格 


/获得 价格 


(2) 建立 图 书信 息 - - 维 数组 ， 用 于 保存 图 书信 息 ， 代 码 如 下 所 示 : 


) 


分 别 调用 类 


"《PHP 从 基础 到 **》'，pal 
《PHP 函数 **》', 'page'=>'8 
《PHP 范例 **》', 'page'=>'700', "writer=>' 小 李 、 小 慌 ','price'=>'85)， 
"《PHP 实战 **》', page=>'750，writer=>' 小 郭 、 小 刘 '\,price=>75) 


(3) 使 用 foreach 语句 通过 循环 输出 图 书信 息 。 在 foreach 循环 体内 部 ， 首 先 对 Book 类 进行 实例 化 ， 然 后 
hb 的 setXxx0 方 法 为 类 中 已 声明 的 属性 赋 初 值 ， 同 时 为 类 中 的 未 声明 的 备注 属性 赋值 ， 最 后 使 用 


/图 书信 息 数组 ， 用 于 模拟 图 书信 息 数据 表 
=>'650', "writer=>' 小 张 、 小 潘 、 小 王 ",'price'=>'58)， 
writer=>' 小 潘 、 小 王 vprice=>80)， 


getXxx0 方 法 打印 出 图 书 的 信息 ， 实 现 该 过 程 的 代码 如 下 所 示 : 
a ‘db.php’; 


foreach ($arrayBook as $key => $aBook) { 


?> 


$book = new Book(); 


$book->setName($aBook[name]); 


$book->setPage($aBook[page]): 


$book->setWriter($aBook[ writer]); 


$book->setPrice($aBook[price]); 
$book->bz = 备注; 


<div style="width:100%; <?php if(Skey < count($arrayBook)-1){?>border-bottom: 1px solid #0463BD;<?php } ?> clear:both:"> 
<div style="width:160px; height:22px; line-height:22px; text-align:left; float-left;"> 


<?php echo $book->getName()?> 


</div> 


<div style="width:160px; height:22px; line-height:22px; border-left:1px solid #0463BD; float:left:"> 


<?php echo $book->getPage0?> 
</ldiv> 


<div style="width:160px; height:22px; line-height:22px; border-left-1px solid #0463BD:; float:left:"> 


<?php echo $book->getWriter()?> 
</div> 


<div style="width:160px; height:22px; line-height:22px; border leftlpx solid #0463BD:; floatleft"> 


<?php echo $book->getPrice0?> 
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<div> 
<div style="width:156px; height:22px; line-height:22px; border-left:1px solid #0463BD; floatleft"> 
<?php echo $book->getOther0?> 
</div> 
</div> 
<?php }?> 


图 秘笈 心 法 


心 法 领悟 337: 在 类 体外 直接 为 类 中 未 定义 的 属性 赋 初 值 。 
在 PHP 面向 对 象 编程 中 ， 在 类 体外 可 以 直接 为 类 中 未 定义 的 属性 赋 初 值 ， 其 示例 代码 如 下 所 示 : 
class Test 


/定义 类 Test 
{ 
} 
S$test = new Test(); /对 Test 类 进行 实例 化 
Stest>x = 明日 ; // 为 Test 类 中 未 定义 的 属性 x 赋 初 值 
echo $test->x; /打印 x 属性 


上 述 代 码 中 ， 首 先 定义 类 Test， 然 后 再 使 用 new 关键 字 对 Test 类 进行 实例 化 ， 并 使 用 该 类 实例 的 对 象 调用 
类 中 未 定义 的 属性 x， 同 时 为 该 属性 赋 初 值 ， 最 后 打印 该 属性 。 运 行 上 述 代码 将 在 页 面 中 打印 出 “明日 ”二 字 ， 
从 而 说 明 即 使 在 类 中 未 定义 某 属性 ， 在 类 体外 也 可 以 对 该 属性 进行 操作 。 


OO 


力 实例 说 明 


本 实例 主要 应 用 __ get( 方 法 获得 类 中 未 定义 属性 的 名 称 。 运 行 本 实例 如 
图 7.32 所 示 , 页 面 中 打印 的 内 容 是 通过 调用 苹果 类 的 属性 打印 的 结果 , 而 弹 
出 的 提示 对 话 框 是 因为 没有 在 类 中 定义 $produceArea 属性 而 通过 _get0 方 法 
弹出 的 。 图 7.32 类 中 未 定义 属性 提示 框 


力 关键 技术 


魔术 方法 _get0 用 于 获得 类 中 不 存在 属性 的 名 称 , 该 方法 必须 带 有 一 个 表示 未 定义 属性 名 称 的 参数 , __get0 
方法 的 使 用 格式 如 下 所 示 : 
function __ get($name) 


// 在 方法 内 部 可 以 使 用 $name 的 值 ， 该 值 即 为 未 定义 属性 的 名 称 


} 
力 设计 过 程 

(1) 定义 苹果 类 Apple， 在 该 类 中 分 别 定义 苹果 颜色 、 形 状 和 重量 等 属性 ， 并 使 用 构造 方法 对 这 些 属性 进 
行 初始 化 ,然后 定义 用 于 获得 苹果 属性 信息 的 getProperty0 方 法 ， 最 后 定义 _get0 方 法 用 于 弹出 提示 未 定义 属性 
名 称 的 对 话 框 ， 实 现 该 过 程 的 代码 如 下 : 


class Apple 

. 
private $color; 1 颜色 
private $shape; /形状 
Private $weight; /重量 
public function __construct ($color, $shape, $weight) /构造 方法 
{ 


$this->color = $color; 
$this->shape = $shape; 
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Sthis >weight = $weight: 
public function getProperty 0 
return ' 这 个 苹果 重 '. $this->weight .是 '. $this->color .'，'. $this->shape . 的 ! “ 
public function __get ($name) 
1 /使 用 _get( 方 法 弹出 未 定义 属性 的 提示 


echo '<script>alert(" 在 类 中 未 定义 属性 '. $name ."! ");</script>"; 
} 


} 
(2) 使 用 new 关键 字 对 苹果 类 Apple 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 苹果 类 中 的 getProperty0 
方法 打印 苹果 的 属性 信息 ， 最 后 使 用 苹果 对 和 象 调用 类 中 未 定义 的 属性 ， 实 现 该 过 程 的 代码 如 下 所 示 : 
require 'Apple.php'; // 使 用 require 语句 包含 Apple.php 文 件 


$apple = new Apple( 红 色 ', 圆 形 '，0.4kg); /使 用 new 关键 字 对 Apple 类 进行 实例 化 
echo $apple->getProperty(; // 调 用 类 中 的 getProperty0 属 性 

echo $apple->produceArea; /1 调用 类 中 未 定义 的 属性 
秘笈 心 法 


心 法 领悟 338: 使 用 _ get( 方 法 实现 错误 信息 的 提示 。 
在 PHP 面向 对 象 编程 方式 中 ， 为 了 防止 因 调用 类 中 未 定义 的 属性 而 导致 程序 运行 期 错误 或 程序 功能 的 不 稳 
定 ， 可 以 在 类 中 指定 _ get(0 方 法 实现 未 定义 属性 的 错误 信息 提示 。 


实例 说 明 
本 实例 主要 讲解 _call0 魔 术 方 法 的 使 用 。 运 行 本 实例 ， 如 图 7.33 所 示 ， a 
将 在 页 面 中 打印 出 图 书 的 信息 和 调用 未 定义 方法 的 名 称 。 其 中 图 书 的 信息 是 cient 


图 书 类 调用 类 中 的 getProperty0 方 法 所 返回 的 结果 ， 而 未 定义 getInfo 方法 的 ” 图 7.33 类 中 未 定义 属性 提示 框 
提示 是 通过 类 中 的 _call0 方 法 的 打印 结果 。 
图 关键 技术 

魔术 方法 _call0 在 调用 类 中 一 个 不 存在 或 不 可 见 的 方法 时 执行 ，_call0 方 法 必须 接收 两 个 参数 ， 用 来 存放 


视图 调用 的 方法 名 及 其 参数 ， 该 方法 的 语法 格式 如 下 : 
Nn __call($name, $arguments) 


上 述 示 例 代码 中 的 参数 $name 用 于 表示 类 中 未 定义 方法 的 名 称 ，$arguments 用 于 表示 未 定义 方法 的 参数 所 
组 成 的 数组 。 


力 设计 过 程 
(1) 定义 图 书 类 Book, 首先 在 该 类 中 定义 $name 和 $price 属性 , 并 使 用 构造 方法 对 这 两 个 参数 进行 实例 化 ， 
然后 定义 getProperty0 方 法 返回 图 书 属性 ， 最 后 定义 _call0 方 法 打印 未 定义 方法 的 名 称 ， 实 现 该 过 程 的 代码 如 


下 所 示 : 
class Book /图 书 类 
二 
private $name; // 书 名 
private $price; /价格 
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public function ”construct ($name, $price) /| 构造 方法 
{ 


Sthis->name = $name; 
S$this->price = $price; 


a function _call ($name, $arguments) N/_call0 方 法 

. echo $name . 方法 未 定义 ; 

和 function getProperty 0 /获得 图 书信 息 的 方法 
return $this->name . 的 价格 是 '. $this->price . 元 


} 
} 


(2) 使 用 new 关键 字 对 Book 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调用 类 中 的 getProperty0 方 法 打印 图 
书信 息 ， 最 后 使 用 实例 后 的 对 象 调 用 类 中 未 定义 的 getInfo0 方 法 ， 代 码 如 下 所 示 : 


require "Book.php'; /包含 Book.php 文件 
$bookName =' 《PHP 范例 **》 / 书 名 

$price = '85'; /价格 

$book = new Book($bookName, $price); /对 Book 类 进行 实例 化 

echo $book->getProperty0 . '<br/>"; /打印 图 书 属性 
$book->getInfo($bookName, $price); /调用 类 中 未 定义 的 getInfo0 方 法 
秘笈 心 法 


心 法 领悟 339: 在 类 中 未 定义 _call0 魔 术 方法 时 ， 调 用 类 中 未 定义 的 方法 会 提示 错误 信息 。 
在 类 体外 可 以 使 用 类 实例 的 对 象 为 类 中 未 定义 的 属性 赋值 ， 但 是 如 果 类 中 没有 定义 _call0 方 法 ， 直 接 调用 
类 中 未 定义 的 方法 时 会 提示 错误 信息 ， 通 过 如 下 示例 代码 进行 演示 : 


class Test /定义 类 Test 

{ 

} 

S$test = new Test(; /对 Test 类 进行 实例 化 
Stest>fun0: // 调 用 类 中 未 定义 的 方法 


在 上 述 示例 代码 中 ， 定 义 类 Test， 并 使 用 new 关键 字 对 其 进行 实例 化 ， 然 后 使 用 类 实例 化 的 对 象 调用 类 中 
未 定义 的 fun0 方 法 ， 将 在 页 面 打印 如 下 错误 提示 。 
Fatal error: Call to undefined method Test::fun() in D:\AppServ\www\MR\OT\t.php on line 7 


法 将 类 的 实例 转化 为 字符 串 


实例 340 于 级 


趣味 指数 : 耸 寅 帘 
图 实例 说 明 
图 的 半径 是 ，2 
本 实例 主要 讲解 如 何 通过 _toString0 魔 术 方 法 将 类 实例 的 对 象 转换 为 字符 这 人 
串 ， 运 行 本 实例 ， 如 图 7.34 所 示 ， 在 页 面 中 打印 出 圆 的 半径 和 该 半 径 对 应 的 圆 - 
面积 ， 其 中 圆 的 面积 是 直接 打印 圆 类 所 实例 对 象 的 结果 。 图 7.34 打印 圆 的 半径 和 面积 
图 关键 技术 


魔术 方法 _toString0 的 作用 是 将 类 实例 的 对 象 转换 为 字符 串 ， 该 方法 的 语法 格式 如 下 : 
return 字 


} 
该 方法 的 返回 值 必须 为 字符 串 类 型 ， 如 果 在 类 中 未 定义 该 方法 ， 当 直接 输出 某 一 个 类 实例 的 对 象 时 ， 将 在 
页 面 中 打印 如 下 错误 提示 : 
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Catchable fatal error: Object of class Test could not be converted to string in D:\AppSerwwwwAMR\O7\O27\tphp 
online 3 

当 在 类 中 定义 _toString( 方 法 后 ， 直 接 输出 类 实例 后 的 对 象 将 在 页 面 中 打印 _toString( 方 法 所 返回 的 字 
符 串 。 


图 设计 过 程 
(1) 创建 圆 类 Circle， 在 圆 类 中 定义 圆 半 径 私有 属性 $radius， 并 使 用 构造 方法 对 该 属性 进行 初始 化 ， 然 后 
定义 _toString0 魔 术 方法 ， 使 用 该 方法 返回 圆 的 面积 值 ， 代 码 如 下 所 示 : 
/定义 圆 类 


class Circle 

UL 
private $radius; / 圆 半 径 属性 
public function __construct ($radius) /| 构造 方法 


S$this->radius = $radius; 
} 
public function _toString 0 /定义 _toString( 方 法 


return " 圆 的 面积 是 : ". (string) number_format((pi0 * pow($this->radius, 2)), 2); 
} 
} 


(2) 使 用 require 语句 包含 Circle.php 文件 , 然后 设 定 圆 的 半径 为 2， 并 使 用 echo 语句 输出 圆 的 半径 和 圆 类 
实例 的 对 象 ， 代 码 如 下 所 示 : 


require 'Circle.php'; // 包 含 CircleArea.php 文件 
Sradius = 2; // 圆 半径 
echo ' 贺 的 半径 是 "Sradius.'<br/>'; /打印 圆 半径 的 值 
echo new Circle($radius); /打印 圆 面积 
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心 法 领悟 340: 使 用 函数 number_format0 对 数字 进行 格式 化 输出 。 
在 对 数字 、 货 币 等 数值 型 数据 进行 操作 时 ， 经 常 需 要 对 数字 进行 格式 化 输出 ，PHP 中 提供 了 专门 对 数字 进 


行 格式 化 输出 的 函数 number_format0 ， 其 语法 格式 如 下 : 
string number_format ( float number [,int decimals [,string dec_point string thousands_sep]] ) 


参数 说 明 : 

number: 必要 参数 ， 指 定 要 进行 格式 化 的 字符 串 。 

decimals: 可 省 参数 ， 指 定 要 保留 小 数 的 位 数 ， 如 果 省 略 该 参数 则 保留 3 位 小 数 。 

dec_point:， 可 省 参数 ， 用 该 参数 指定 的 字符 替代 小 数 点 ， 该 参数 与 参数 thousands_sep 同时 使 用 。 
thousands_sep: 可 省 参数 ， 用 该 参数 指定 的 字符 蔡 代 千 位 分 隔 符 ， 该 参数 与 参数 dec_point 同时 使 用 。 


力 实例 说 明 


运行 本 实例 ， 如 图 7.35 所 示 ， 在 页 面 中 打印 出 未 定义 属性 的 提示 信息 以 及 “小 明 ” 的 年 龄 和 体重 信息 ， 其 
中 类 中 未 定义 属性 sex 的 提示 信息 是 通过 魔术 方法 _isset0 打 印 的 。 


在 关中 未 定义 必 性 sex 


小 明 的 年 龄 时: 12 竺 ， 体 重症 : 4 公斤 


图 7.35 打印 人 的 属性 信息 
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图 关键 技术 


魔术 方法 _isset0 是 当 使 用 isset0 函 数 判断 类 中 未 定义 的 属性 是 否 被 设置 时 所 调 


下 所 示 : 


function __isset ($name) 


} 


魔术 方法 _isset0 必 须 包含 


图 设计 过 程 
(1) 定义 人 类 Person， 在 该 类 中 定义 人 的 名 称 、 年 龄 和 体重 等 属性 ， 并 定义 与 这 些 属 性 相对 应 的 setXxx0 
方法 和 getXxx0 方 法 ， 代 码 如 下 所 示 : 


class Person 


i 


} 


echo $person->getName(). 的 年 龄 是 ，'.$person->getAge0. 岁 ， 体 重 是 : “S$person->getWeight0 ; 


Private $name; 

private $age; 

Pprivate $weight; 

public function setName ($name) 


S$this->name = $name; 


} 
public function getName 0 
{ 


Teturn $this->name; 


小 
public function setAge ($age) 


{ 
$this->age = $age; 


} 
public function getAge 0 
{ 

Teturn $this->age; 


} 
public function setWeight ($weight) 
{ 

S$this->weight = $weight; 


} 

public function getWeight () 
Teturn $this->weight; 

J 

public function __isset ($name) 


echo "在 类 中 未 定义 属性 '. $name; 
} 


-个 用 于 代表 类 中 未 定义 属性 的 名 称 参 数 。 


的 ， 该 方法 的 使 用 格式 如 


/名 称 
/年 龄 
1/ 体 重 
1/ 设置 名 称 


/获得 名 称 


1/ 设置 年 龄 


/获得 年 龄 


/设置 体重 


/获得 体重 


/定义 _isset( 方 法 


(2) 使 用 new 关键 字 对 Person 类 进行 实例 化 , 然后 分 别 调用 该 类 中 相应 的 setXxx0 方 法 为 类 中 的 属性 赋 初 
值 ， 并 使 用 函数 isset0 判 断 类 中 未 定义 的 sex 属性 是 否 被 设置 ， 实 现 该 过 程 的 代码 如 下 所 示 : 


require ‘Person.php'; 

$person = new Person(); 
$person->setName( 小 明 ); 
$person->setAge(12); 
$person->setWeight(45 公斤 ); 
isset($person->sex); 

echo ‘<br/>'; 


/包含 Person.php 文 件 

/实例 Person 类 

/设置 名 称 

/设置 年 龄 

/设置 体重 

/判断 是 否 在 类 中 定义 了 sex 属性 
/换行 

/打印 信息 
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图 秘笈 心 法 

心 法 领悟 341: 使 用 isset0 函 数 判断 变量 是 否 被 设置 值 。 

PHP 编码 时 ,有 时 需要 判断 某 一 变量 是 否 被 设置 了 值 ,然后 再 对 该 变量 进行 操作 , PHP 中 可 以 使 用 函数 isset0 
判断 某 个 变量 是 否 被 设置 了 值 ， 该 函数 的 使 用 格式 如 下 所 示 : 

bool isset ( mixed var [, mixed var [, .….]] ) 

如 果 该 函数 的 参数 列表 所 指定 的 变量 都 已 经 设置 了 值 则 该 函数 返回 TRUE， 反 之 返回 FALSE。 


实例 342 中 级 


趣味 指数 : 耸 催 人生 
力 实例 说 明 
本 实例 主要 讲解 魔术 方法 _unset0 的 使 用 方法 。 运 行 本 实例 , 如 图 7.36 aaaeaaas 


所 示 , 在 页 面 中 打印 出 使 用 unset0 函 数 撤销 类 中 未 定义 的 价格 属性 的 结果 。 图 7.36 打印 Car 类 中 未 定义 的 属性 
图 关键 技术 
魔术 方法 “unset0 是 当 使 用 unset0 函 数 撤销 类 中 未 定义 的 属性 时 所 调用 的 ， 该 方法 的 使 用 格式 如 下 所 示 : 


function __unset ($name) 
E 


} 

魔术 方法 _unset0 必 须 包 含 一 个 用 于 代表 类 中 未 定义 属性 的 名 称 参数 。 
图 设计 过 程 

(1) 建立 汽车 类 Car， 在 类 中 定义 汽车 的 品牌 和 颜色 属性 ， 然 后 使 用 构造 方法 为 这 两 个 属性 赋 初 值 ， 最 后 
定义 魔术 方法 _unset0 打 印 撤销 类 中 未 定义 属性 时 的 提示 信息 ， 代 码 如 下 所 示 : 


class Car 

上 
private $brand; /品牌 
private $color; /颜色 
public function __construct ($brand, $color) /构造 方法 
{ 


$this->brand = $brand; 
$this->color = $color; 
} 
public function __unset ($name) /定义 _unset( 方 法 


echo 在 '. ”CLASS . 类 中 未 定义 . $name . 属性 ': 
} 
} 


(2) 使 用 require 语句 包含 Car.php 文件 ， 然 后 使 用 new 关键 字 对 汽车 类 进行 实例 化 并 生成 汽车 对 象 $car， 
最 后 使 用 unset( 方 法 撤销 类 中 未 定义 的 价格 属性 ， 代 码 如 下 所 示 : 
require 'Car.php': /包含 Carphp 文件 


$car = new Car( 奥 迪 ', 黑色 ); /使 用 new 关键 字 实 例 Car 类 
unset($car->price); /使 用 函数 unset0 释 放 Car 类 中 未 定义 的 属性 price 
力 秘笈 心 法 


心 法 领悟 342: PHP 中 的 魔术 常量 。 
本 实例 中 ， 使 用 _CLASS_ 获得 当前 类 的 名 称 ， 类 似 这 样 的 常量 在 PHP 中 被 称 为 魔术 常量 ， 其 中 PHP 中 
常用 的 魔术 常量 及 其 说 明 如 表 7.1 所 示 。 
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表 7.1 PHP 中 常用 的 魔术 常量 


魔术 常量 名 称 说 明 
_IINE_ | 返回 运行 中 PHP 脚本 的 当前 行 的 行 号 
_FIE | 返回 当前 PHP 脚本 的 完整 路 径 和 文件 名 
_FUNCTION | 返回 当前 函数 的 名 称 
_ CLASS __ | 返回 当前 类 的 名 称 
_ METHOD__ 返回 当前 类 中 成 员 方法 的 名 称 


方法 自动 导入 类 文件 


实例 343 赵 味 指数 : 从 全 宣 


图 实例 说 明 
证 条 是 红色 的 
本 实例 主要 讲解 如 何 使 用 魔术 方法 _autoload0 自动 加 载 类 文件 。 运行 i 


本 实例 ， 如 图 7.37 所 示 ， 在 页 面 中 分 别 打 印 出 苹果 和 桔子 的 颜色 信息 。 
在 实现 本 实例 时 ,将 Apple 类 和 Orange 类 分 别 存放 在 与 这 两 个 类 同名 ” 图 737 打印 蕴 果 和 桔子 的 颜色 属性 
的 类 文件 中 ， 然 后 在 index.php 文件 中 不 使 用 require 等 包含 语句 包含 这 两 个 类 文件 ， 而 使 用 _autoload( 方 法 根 
据 类 名 自动 导入 相应 的 文件 。 
图 关键 技术 
魔术 方法 _autoload0 包 含 一 个 参数 ， 该 参数 是 当前 页 面 中 所 定义 类 的 名 称 ， 在 该 魔术 方法 内 部 ， 可 以 使 用 
require 等 包含 语句 和 该 方法 的 参数 所 代表 的 类 名 来 自动 加 载 类 ，__autoload0 的 使 用 格式 如 下 所 示 : 
function _autoload($name){ 


} 


图 设计 过 程 
(1) 定义 苹果 类 Apple 和 桔子 类 Orange， 并 分 别 在 这 两 个 类 中 定义 用 于 获得 颜色 的 getColor0 方 法 ， 代 码 
如 下 所 示 : 
class Apple 1/ 苹果 类 
public function getColor (0) // 获 得 苹果 颜色 方法 
return 苹果 是 红色 的 ': 
Orange /精子 类 
public function getColor (0) // 获 得 桔子 颜色 的 方法 
return 桔子 是 橙色 的 ' 
} 


(2) 定 义 _autoload0 方 法 的 实现 .在 该 方法 内 部 首先 构建 自动 包含 类 文件 的 路 径 ,然后 使 用 函数 fle_exists0 
判断 该 文件 是 否 存在 ， 如 果 存 在 ， 则 使 用 require_once 语句 包含 该 文件 ， 反 之 返回 FALSE 值 ， 实 现 该 过 程 的 代 
码 如 下 所 示 : 

function __autoload ($className) /定义 _autoload( 方 法 


攻 
$file = dirmname(_FILE_) . /class/ . $className . .php': /包含 文件 的 路 径 
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if (! file_exists($file)) { /1/ 判 断 文 件 是 否 存在 
return false; /不 存在 返回 false 
}else{ 
require_once $file; /存在 则 包含 该 文件 


} 
} 


(3) 使 用 require 语句 包含 autoload.php 文件 ， 然 后 使 用 new 关键 字 分 别 对 苹果 类 和 桔子 类 进行 实例 化 ， 
最 后 通过 这 两 个 类 实例 的 对 象 分 别 调用 各 自 的 getColor( 方 法 打印 苹果 和 桔子 的 颜色 ， 代 码 如 下 所 示 : 


require ‘autoload.php'; /包含 autoload.php 文件 

$apple = new Apple0:; /对 苹果 类 进行 实例 化 

S$orange = new Orange(); /对 桔子 类 进行 实例 化 

echo $apple->getColor0 . ‘<br/>"; /打印 苹果 颜色 

echo $orange->getColor0; /打印 桔子 颜色 
秘笈 心 法 


心 法 领悟 343: 使 用 函数 file_exists0 判 断 指定 的 文件 是 否 存在 。 
本 实例 中 ， 在 魔术 方法 _autoload0 内 部 使 用 函数 file_exists0 判 断 指定 的 类 文件 是 否 存 在 ， 该 函数 的 语法 格 
式 如 下 所 示 : 


bool file_exists ( string filename ) 
如 果 fename 指定 的 文件 或 目录 存在 则 返回 TRUE， 和 否则 返回 FALSE。 


7.8 设计 模式 
面向 对 象 的 程序 开发 方式 ， 不 仅 表 现在 程序 的 语法 规则 和 语言 特性 上 ， 更 主要 的 是 表现 一 种 设计 思想 。 当 


设计 一 个 软件 时 ， 很 多 设计 概念 被 反复 使 用 ， 最 终 形成 了 一 种 规则 ， 这 些 规则 通常 被 称 为 设计 模式 。 本 节 将 通 
过 具体 实例 讲解 PHP 常用 设计 模式 的 应 用 方式 。 


实例 344 


力 实例 说 明 


本 实例 主要 讲解 如 何 使 用 单 例 模式 制作 一 个 基于 MySQL 数据 库 的 数据 库 管理 类 。 运 行 本 实例 ， 如 图 7.38 
所 示 ， 首 先 在 用 户 登 录 文本 框 中 输入 用 户 名 和 密码 ， 然 后 单 击 表单 中 的 “登录 ”按钮 ， 如 果 用 户 名 和 密码 经 后 
全 代码 验证 正确 则 当前 页 面 将 跳 转 到 登录 成 功 信息 提示 页 面 ， 如 果 错 误 则 在 页 面 打印 错误 提示 。 在 上 述 过 程 中 ， 
对 数据 库 管 理 模块 的 开发 采用 PDO 技术 ， 设 计 上 采用 单 例 模式 进行 编码 。 


从 明日?7 困 且 同 


em 


| Ai 
用 户 晤 录 


(O19.010 TO 


图 7.38 ”用户 登 录 表单 


图 关键 技术 
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单 例 模式 指 的 是 在 程序 应 用 范围 内 只 对 指定 的 类 创建 一 个 实例 ， 也 就 是 说 单 例 模式 只 包含 一 个 对 象 ， 就 是 


单 例 本 身 ，PHP 使 用 单 例 模式 设计 的 类 通常 应 该 满足 如 下 要 求 : 


单 例 模式 的 类 通常 拥有 一 个 私有 的 构造 方法 和 一 个 私有 的 克隆 方法 ， 这 样 可 以 确保 用 户 无 法 通过 创建 


对 象 或 者 克隆 的 方式 对 其 进行 实例 化 。 


单 例 模式 的 类 包含 一 个 静态 的 用 于 保存 当前 类 实例 的 成 员 变 量 ， 以 及 一 个 静态 方法 ， 该 静态 方法 负责 
对 其 本 身 进 行 实例 化 ， 然 后 将 实例 化 后 的 对 象 保存 到 类 中 所 声明 的 静态 变量 中 ， 从 而 确保 一 个 对 象 被 


创建 。 
PHP 单 例 模式 的 基本 形式 如 下 所 示 : 
class Singleton 
: Private static $instance; 
public static function getInstance () 


if (null == self::$instance) { 
self::$instance = new Db0; 


Teturn self::$instance; 
二 于 function ”construct 0 
es function _clone 0 
Vg 的 其 他 方法 


1/ 获 得 类 的 对 象 
$singleton = Singleton::getInstance(); 


/保存 当前 类 实例 后 的 对 象 
// 静 态 方法 ， 返 回 类 实例 


/如果 未 定义 


/返回 当前 对 象 
/私有 构造 方法 
/私有 克隆 方法 


由 上 述 代码 可 知 , 在 类 外 部 通过 类 名 直接 调用 类 中 的 用 于 返回 当前 类 实例 的 静态 方法 即 可 获得 当前 类 实例 。 


力 设计 过 程 


(1) 建立 数据 库 连 接 类 Db， 在 类 中 定义 用 于 保存 当前 类 实例 的 静态 成 员 变 量 $instance， 并 定义 静态 方法 
getInstace0 ， 在 该 方法 内 部 ， 将 当前 类 实例 的 对 象 赋 给 静态 成 员 变 量 $instance 并 返回 ， 然 后 定义 私有 的 构造 方 
法 和 克隆 方法 ,这 样 就 构建 了 单 例 模式 的 基本 框架 , 接 下 来 创建 getConnId0 方 法 ,该 方法 用 于 返回 使 用 PDO 技 
术 连 接 数据 库 后 的 句柄 ， 最 后 创建 数据 库 查 询 方法 query0 实 现 对 数据 库 的 查询 操作 。 实 现 上 述 过 程 的 代码 如 下 


所 示 : 
class Db 


{ 
Private static $instance; 


public static function getInstance () 


if (null == self::$instance) { 
self::$instance = new Db(); 


} 
Teturn self::$instance; 
站 
private function __construct 0) 
0 
private function _clone 0 


0 
private function getConnId 0 
{ 


$config = parse_ini_file(dimame(_ FILE). /config:ini); 
$dsn = 'mysql:host=" . $config[host] . ;dbname=" . $config['dbname']; 
$pdo = new PDO ($dsn, $config[username], $config[ password"]); 


$pdo->query(set names ' . $config[ charset]); 
Teturn $pdo; 


/其 据 库 类 


// 保 存 当前 类 实例 后 的 对 象 
1/ 静态 方法 ， 返 回 类 实例 


/如果 未 定义 


/私有 构造 方法 

/私有 克隆 方法 

/| 获得 数据 库 连 接 ID 的 方法 
/| 解析 配置 文件 

/配置 数据 源 名 称 

/实例 PDO 对 象 


/设置 字符 集 
/版 回 PDO 对 象 
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public function query ($sql) // 查 询 方法 
上 
$pdo = $this->getConnId0: /获得 PDO 对 象 
$sqlType = trim(substr($sql, 0, 6)); /获得 查询 语句 类 型 
if ($sqlType 一 update || $sqlType 一 delete || $sqlType 一 insert) { 
Teturn $pdo->query ($sq]); // 如 果 是 update、delete 或 insert 语句 则 返回 SQL 语句 执行 结果 
} elseif ($sqlType 一 'select) { // 如 果 是 select 语句 
S$tmpArray =array(; // 定 义 二 维 数组 
Sresults = $pdo->query($sq]); /| 执行 select 语 句 
foreach ($results as $result) { /| 将 结果 保存 到 二 维 数组 中 
array_push($tmpArray, $result); 
Teturn $tmpArray; /返回 结果 
}else{ 
return null; // 不 是 update、delete、insert 或 select 语句 ， 则 返回 null 
} 


} 


} 
(2) 建立 用 户 登 录 表 单 ， 其 实现 过 程 请 详 见 本 书 附带 光盘 。 当 用 户 在 表单 中 输入 用 户 名 和 密码 ， 单 击 “ 提 
交 ” 按 钮 后 ， 将 通过 如 下 代码 验证 用 户 的 登录 信息 是 否 正 确 : 
if(isset($_POST['username']) && trim($_POST['username'])!=") 
{ 
Tequire_once 'Db.php'; 
$username = trim($_POST[username]); 
$password = trim(md5($_POST['password]); 
$db = Db::getInstance(); 
$arrayUser = $db->query("select id from tb_user where username="". $username."" and password =".$password.”™"); 
if(count($arrayUser)>0){ 
$_SESSION['loginUsername'] = $username; 
echo '<script>window.location.href="success.php";</script>"; 
Jelse { 
echo '<div style="width:300px; height:30px; line-height:30px; border:1px solid #E59B04; background-color:#FCF2E0; color:#FF0000;"> 用 户 
名 或 密码 输入 有 误 </div>"; 
} 


} 

上 述 代 码 首 先 判断 用 户 是 否 提交 了 表单 ， 如 果 是 ， 则 通过 Db 类 的 getInstance0 方 法 获得 类 的 实例 ， 并 通过 
该 对 象 调 用 类 中 的 query0 方 法 执行 查询 ， 根 据 查询 结果 的 记录 数 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 
果 记 录 数 大 于 1， 则 说 明 用 户 登 录 信 息 有 效 。 


秘笈 心 法 
心 法 领悟 344: 使 用 函数 parse_ini_file0 解 析 .ini 文件 。 


在 项 目 开发 中 , 经 常 需要 将 项 目的 一 些 配置 参数 保存 到 .ini 文件 中 , 例如 本 实例 将 数据 库 连 接 参数 保存 到 专 
门 的 config.ini 文件 中 ， 以 便于 对 项 目 配置 信息 的 修改 和 统一 管理 。 函 数 parse_ini_file0 的 语法 格式 如 下 所 示 : 

array parse_ini_file ( string filename [, bool process_sections] ) 

函数 parse_ini_file0 载 入 一 个 由 fename 指定 的 .ini 文件 ， 并 将 其 中 的 设置 作为 一 个 联合 数组 返回 。 如 果 
process_sections 参数 设 为 TRUE， 将 得 到 一 个 多 维 数组 ， 包 括 配置 文件 中 每 一 节 的 名 称 和 设置 ，process_sections 
的 默认 值 是 FALSE。 


实例 345 


图 实例 说 明 


本 实例 主要 讲解 在 PHP 面向 对 象 编程 中 策略 模式 的 应 用 方法 。 运 行 本 实例 ， 分 别 如 图 7.39 和 图 7.40 所 示 ， 
其 中 图 7.39 所 示 为 在 正 下 运行 的 结果 ， 图 7.40 所 示 为 在 火狐 浏览 器 下 运行 的 结果 。 从 运行 结果 可 知 ， 本 实例 
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会 根据 不 同 浏览 器 的 类 型 在 页 面 中 打印 相应 浏览 器 的 名 称 。 


EG 引 
名 EL 

下 十 @) [加 http:yue.l6s 1 sq/mrorss/ 可 加 车 到 | 全 | 

到 


当前 浏览 器 是 下 
习 
BED 3 2 
图 7.39 打印 浏览 器 的 类 型 为 正 
图 关键 技术 


当 寺 浏览 八 是 Firefox 


FE 
图 7.40 打印 浏览 器 的 类 型 是 Firefox 


策略 模式 指 的 是 程序 中 涉及 决策 控制 的 一 种 模式 。 策 略 模式 通常 定义 一 个 抽象 基 类 ， 然 后 根据 不 同情 况 创 
建 不 同 的 子 类 ， 其 中 一 个 简单 的 策略 模式 框架 如 下 所 示 : 


abstract class Strategy 
abstract public function fun (); 
Childl extends Strategy 
public function fun (0 


/Childl 中 fun0 方 法 所 实现 的 功能 
} 


} 
class Child2 extends Strategy 

public function fun (0) 

WChild2 中 fun0 方 法 所 实现 的 功能 

} 
f( 条 件 1==true) { 

$obj = new Child10; 
Jelse { 
$obj = new Child20; 


} 
$obj->fun0; 


/定义 抽象 的 基 类 

/定义 抽象 方法 fun0 

/定义 子 类 Child1， 使 其 继承 基 类 Strategy 
1/ 实现 fun0 方 法 的 功能 


/定义 子 类 Child2， 使 其 继承 基 类 Strategy 
/实现 fun0 方 法 的 功能 


// 如 果 条 件 1 为 真 
/生成 子 类 Child1 的 实例 对 象 


/生成 子 类 Child2 的 实例 对 象 


上 述 示例 代码 中 首先 定义 抽象 基 类 Strategy, 并 在 类 中 定义 抽象 方法 fun0, 然后 分 别 定义 类 Childl 和 Child2， 
使 这 两 个 类 分 别 继承 基 类 Strategy， 在 这 两 个 子 类 的 内 部 实现 fun0 的 功能 ， 完 成 以 上 类 的 定义 后 ， 就 可 以 根据 


不 同 的 条 件 对 不 同 的 子 类 进行 实例 化 。 


图 设计 过 程 


(1) 定义 抽象 的 Browser 类 ， 并 在 该 类 中 声明 抽象 方法 getType0， 然 后 定义 子 类 Ie 和 Fox， 使 这 两 个 类 分 
别 继承 基 类 Browser， 然 后 在 类 体内 完成 对 getType0 类 的 定义 ， 代 码 如 下 所 示 : 


abstract class Browser 
长 

abstract public function getType 0: 
class Je extends Browser 

public function getType () 

return TE'; 

} 
上 
class Fox extends Browser 


public function getType 0 


/定义 抽象 类 Browser 


/定义 类 
/获得 类 型 方法 


/定义 火狐 类 
/获得 类 型 方法 
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return Firefox ; 
} 


} 
(2) 使 用 header0 函 数 设置 页 面 编码 , 并 使 用 require 语句 包含 Browser.php 文件 ,然后 定义 getBrowserType0 
方法 获得 浏览 器 类 型 ， 代 码 如 下 所 示 : 


header(content-type:text/html; charset=utf-8); /定义 页 面 编码 
require ‘Browser.php'; /包含 Browser.php 文件 
function getBrowserType () /定义 获得 浏览 器 类 型 的 方法 
if (strstr($_SERVER[HTTP_USER_AGENT, "IE")) { /| 判断 是 否 为 下 浏览 器 
$b = new Ie(; /| 实例 le 类 
}else{ 
$b = new Fox(); /实例 Fox 类 
Teturn $b->getType(); /返回 浏览 器 类 型 
} 
echo ' 当 前 浏览 器 是 '. getBrowserType0:; /执行 getBrowserType0 方 法 
图 秘笈 心 法 


心 法 领悟 345: 使 用 函数 header0 设 置 页 面 编 码 。 

通过 HTML 语言 的 <meta> 标 记 可 以 设置 页 面 编码 ， 那 么 如 果 在 页 面 中 不 包含 任何 HTML 标记 的 PHP 页 面 
如 何 设置 页 面 编码 呢 ? PHP 提供 了 用 于 发 送 HTTP 头 信息 的 header0 函 数 ， 可 以 通过 如 下 方式 设置 页 面 编码 

header(content-type:text/html; charset=utf-8) 

上 述 代码 可 以 设置 文件 的 内 容 类 型 为 text/html， 页 面 编 码 为 utf-8 编码 。 


用 户 访问 权限 中 级 


力 实例 说 明 


本 实例 主要 讲解 如 何 使 用 工厂 模式 对 用 户 权限 进行 管理 。 运 行 本 实例 ， 如 图 7.41 所 示 ， 在 页 面 中 将 打印 出 
不 同 用 户 的 类 型 及 各 项 操作 的 访问 权限 。 制 作 本 实例 时 ， 首 先 创建 抽象 的 用 户 权限 类 ， 然 后 分 别 定义 浏览 、 添 
加 、 更 改 和 删除 等 子 类 ， 使 之 继承 基 类 用 户 权限 类 ， 然 后 根据 不 同 用 户 的 权限 ， 重 写 用 户 权 限 类 中 的 方法 ， 最 
后 创建 用 户 权限 工厂 来 根据 不 同 用 户 类 别 返 回 相应 的 对 象 。 


| = 
Www.mrbecd.com eal|gs [CETTE 


全 
至 创建 四 用 
乙 


图 7.41 电子 相册 用 户 权限 列表 
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潞 


图 关键 技术 

工厂 模式 是 指 创建 一 个 类 似 于 工厂 的 类 ， 通 过 对 类 中 成 员 方 法 的 调用 返回 不 同类 型 的 对 象 。 使 用 工厂 模式 
时 ， 首 先 创建 一 个 基 类 ， 然 后 根据 对 象 类 型 的 不 同 来 创建 不 同 的 扩展 类 ， 最 后 定义 工厂 类 来 根据 不 同 的 条 件 返 
回 相 应 的 对 象 。 工 厂 模式 的 示例 代码 如 下 所 示 : 


abstract class Father /定义 基 类 
} 
class Childl extends Father /定义 子 类 1 
{ 
} 
class Child2 extends Father /定义 子 类 2 
{ 
} 
class Factory /定义 工厂 类 
public static function create ($condition) /创建 对 象 
让 ($condition == 条 件 1){ 
return new Child10 
} elseif ($condition == “条件 2) { 
return new Child2() 
} 


- 述 示例 代码 中 ， 首 先 定义 抽象 基 类 Father， 然 后 定义 子 类 Childl 和 Child2， 使 之 分 别 继承 基 类 Father， 
在 实际 应 用 中 还 应 该 重 写 或 定义 子 类 Childl 和 Child2 中 的 方法 ， 最 后 定义 工厂 类 Factory， 并 在 该 类 中 定义 静 
态 的 create( 方 法 来 根据 不 同 的 条 件 返回 相应 的 对 象 。 


侈 提示: 抽象 基 类 也 可 以 使 用 接口 来 代替 。 
设计 过 程 
(1) 定义 用 户 权限 基 类 UserPermission， 然 后 在 该 基 类 中 定义 select0、add0 、edit0 和 delete0 等 方法 ， 然 
后 分 别 定义 子 类 GuestPermission 、 MemberPermission 和 AdminPermission ， 并 使 这 些 类 分 别 继承 基 类 


UserPermission, 同时 根据 不 同类 的 功能 对 基 类 中 的 方法 进行 重 写 , 最 后 定义 用 户 权 限 工厂 UserPermissionFactory 
来 根据 不 同 用 户 的 类 别 对 相应 的 子 类 进行 实例 化 并 返回 ， 实 现 该 过 程 的 代码 如 下 所 示 : 


abstract class UserPermission /定义 抽象 的 用 户 权限 类 
public function select 0 /定义 查询 方法 
Teturn true; 
public function add 0 /定义 添加 方法 
Teturn false; 
Ls function edit 0 /定义 编辑 方法 
return false; 
function delete (0) /定义 删除 方法 
Teturn false; 
} 
} 
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class GuestPermission extends UserPermission /定义 浏览 者 权限 类 
0 
class MemberPermission extends UserPermission /定义 会 员 权限 类 
public function add (0 / 重 写 添加 方法 
{ 
return true; 
} 
class AdminPermission extends UserPermission /定义 管理 员 权限 类 
public function add 0 / 硬 写 添加 方法 
下 
return true; 
public function edit 0 // 重 写 编辑 方法 
1 
Teturn true; 
} 
public function delete 0 // 重 写 删 除 方法 
{ 
Teturn true; 
y } 
class UserPermissionFactory /用 户 权限 工厂 
{ 
public static function getUser ($userType) /获得 用 户 权限 方法 
{ 
switch ($userType) { 
case 'GUEST': 
return new GuestPermission(); /返回 普通 浏览 者 权限 对 象 
break; 
case MEMBER': 
return new MemberPermission(); /返回 会 员 权限 对 象 
break; 
case ' ADMIN : 
return new AdminPermission(); /返回 管理 员 权限 对 象 
break; 


上 
} 
(2) 定义 二 维 数组 $users， 使 用 该 数组 保存 用 户 名 称 及 权限 类 别 ， 代 码 如 下 所 示 : 
$users = array( 
De ‘ype => 'GUEST), 


4->amay(name=>'360, ‘type’ => "MEMBER), 


5=>array(name=>'MR’ ‘type’ => ‘ADMIN) 


); 
(3) 使 用 require 语句 包含 UserPermissionFactory.php 及 db.php 文件 ， 然 后 使 用 foreach 循环 语句 遍历 用 户 
数组 ， 并 根据 用 户 类 别 通过 用 户 权限 工厂 生成 相应 的 用 户 权 限 对 象 ， 最 后 打印 用 户 权限 信息 ， 实 现 该 过 程 的 代 


码 如 下 所 示 : 

<?php 

require 'UserPermissionFactory.php': // 包 含 用 户 权 限 工厂 所 在 文件 

require 'db.php': /包含 用 户 信息 数组 所 在 文件 

foreach ($users as $user){ /W 访 历 用 户 权限 数组 
$userPermission = UserPermissionFactory::getUser($user['type"]); /获得 用 户 权限 对 象 

?> 

<!L- 以 下 代码 用 于 打印 用 户 权 限 信息 -> 

<tr> 


<td style="width:80px; height:22px; border:1px solid #E0056F;"><?=$user[name]?></td> 

<td style="width:80px; height:22px; border:1px solid #E0056F;"><?=str_replace(ADMIN,, 管理 员 ', str_replace(MEMBER', 会 员 ', 
str_replace(GUEST', ' 访 客 ', $user['type1)))?></td> 

<td style="width:80px; height:22px; border:1px solid #E0056F:"><?-$userPermission->select0? 是 : 否 ?></td> 
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<td style="width:80px; height:22px; border:1px solid #E0056F:"><?-$userPermission ->add0? 是 :' 否 ?></td> 
<td style="width:80px; height:22px; border:1px solid #E0056F:"><?-$userPermission->edit0? 是 : 否 ?></d> 
<td style="width:80px; height:22px; border:1px solid #E0056F:"><?-$userPermission->delete0? 是 : 否 ?></td> 

<htr> 

<?php 

1 

?> 


图 秘 签 心 法 
心 法 领悟 346: 使 用 工厂 模式 设计 数据 库 管理 类 。 
根据 本 实例 所 介绍 的 工厂 模式 可 知 ， 如 果 采 用 该 模式 设计 数据 库 管理 类 ， 可 以 使 用 相同 的 代码 实现 对 不 同 
数据 库 的 管理 。 下 面 给 出 采用 工厂 模式 设计 的 数据 库 管 理 类 的 模板 代码 : 
abstract class Db // 定 义 抽象 的 数据 库 管理 类 
{ 
abstract public function insert (); 
abstract public function delete (0; 
abstract public function update (); 
abstract public function select 0; 


} 
class MySQL extends Db /定义 MySQL 数据 库 管理 类 


public function insert 0 
是 function delete () 
a function update () 
pte function select () 


} 
class Oracle extends Db /定义 Oracle 数据 库 管理 类 
{ 

public function insert () 

0 

public function delete (0 

0 

public function update () 

他 

public function select (0 

0 
class SQLServer extends Db /定义 SQL Server 数据 库 管理 类 
下 

public function insert () 

0 

public function delete () 

0 

public function update () 

0 

public function select () 

0 
} 
class DbFactory /定义 数据 库 管理 类 工厂 
E 

public static function getDb ($TYPE) /根据 不 同 的 标识 返回 不 同 的 数据 库 实例 

Switch ($TYPE) { 
MYSQL: 
return new MySQLO; 
break; 
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'SQLSERVER- 
retum new SQLServer0: 
break; 

} 

} 


中 

在 上 述 模板 代码 中 ， 首 先 定义 抽象 的 数据 库 管理 类 Db， 然 后 分 别 定义 子 类 MySQL、Oracle 和 SQL Server， 
并 定义 数据 库 管理 类 工厂 DbFactory， 在 该 工厂 中 定义 静态 的 getDb0 方 法 ， 用 来 根据 不 同 的 标识 返回 数据 库 管 
理 类 对 象 ， 这 样 通过 该 对 象 就 可 以 实现 采用 相同 的 方法 对 不 同 数据 库 进 行 管理 。 
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第 8 章 MySQL 数据 库 与 PHP 
8.1 MySQL 服务 器 的 启动 和 关闭 


PHP 在 开发 Web 站 点 或 一 些 管理 系统 时 ， 需 要 对 大 量 数 据 进行 存储 。XML 文件 和 文本 文件 虽然 可 以 作为 
数据 的 载体 ， 但 不 易 进行 管理 和 对 大 量 数据 的 存储 ， 所 以 在 项 目 开发 时 ， 数 据 库 就 显得 非常 重要 。PHP 可 以 连 
接 的 数据 库 种 类 较 多 ， 其 中 MySQL 数据 库 与 其 兼容 较 好 ， 在 PHP 开发 中 被 广泛 应 用 。 


高 级 


趣味 指数 : 俩 人 规 侠 重 


图 实例 说 明 

如 果 想 学 习 PHP 语言 ， 那 么 就 必须 要 学 MySQL。PHP 与 MySQL 是 最 佳 的 组 合 ， 虽 然 PHP 如 今 支持 更 多 
的 数据 库 ， 例 如 Access、SQL Server、Oracle、DB2 等 ， 但 是 无 论 在 LAMP 组 合 (LINUX + Apache + MySQL + 
PHP) ， 还 是 AMP 组 合 (Apache+MySQL + 了 PHP) 中 ，MySQL 的 地 位 丝毫 没有 动摇 。 

在 Windows 操作 系统 中 ， 启 动 MySQL 服务 器 可 以 使 用 命令 模式 进行 。 


图 关键 技术 
本 实例 的 关键 是 在 命令 提示 符 下 输入 启动 MySQL 服务 器 的 命令 , 完成 MySQL 服务 器 的 启动 , 其 命令 如 下 : 
net start mysql 
图 设计 过 程 
在 Windows 操作 系统 下 启动 MySQL 服务 器 的 步骤 如 下 : 
(1) 选择 “开始 ”/“ 运 行 ”命令 ， 在 弹出 的 “运行 ”对 话 框 的 “打开 ”文本 框 中 输入 cmd 命令 ， 按 Enter 


键 进入 命令 提示 符 窗口 ， 如 图 8.1 所 示 。 
(2) 在 命令 提示 符 下 输入 启动 MySQL 服务 器 的 命令 ， 如 图 8.2 所 示 。 

我 的 电 府 本 了 zl 

[ee 让 所 汪 人 机 区 基本 6 

I 9 .0 ee | 

局 打 印 机 和 传 丰 

O) es Ce ww | wow.| 

门 失 四 2. 打开“ 运行 ”对话 框 输入 cmd 命 令 


1. 单 击 “ 开 始 ”菜单 ， 选 择 “运行” 命令 


NET HELPHSG 2182 上 


FY | 


8.1 启动 MySQL 服务 器 第 1 步 图 8.2 成 功 启动 MySQL 服务 器 


力 秘笈 心 法 


心 法 领悟 347: 手动 启动 MySQL 服务 。 
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启动 MySQL 服务 器 还 有 另外 一 种 方法 ， 即 通过 选择 “开始 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ” 命 令 ， 
打开 Windows 服务 管理 器 ， 在 服务 器 的 列表 中 找到 “mysql” 服 务 ， 单 击 鼠 标 右键 ， 从 弹出 的 快捷 菜单 中 选择 
“启动 ”命令 即 可 。 


实例 348 


图 实例 说 明 
启动 MySQL 服务 只 是 应 用 MySQL 的 第 一 步 ， 如 果 想 要 操作 MySQL 数据 库 ， 就 要 学 会 连接 MySQL 服务 
器 。 本 实例 详细 讲解 如 何在 命令 提示 符 下 连接 MySQL 服务 器 。 


图 关键 技术 


选择 “开始 ”/“ 运 行 ”命令 ， 输 入 cmd 命令 ， 进 入 命令 提示 符 提示 框 ， 在 其 中 输入 如 下 命令 : 
mysql -uName —p Password 
“mysql” 与 “-u”、“Name” 与 “-p” 之 间 有 一 个 空格 。Name 表示 进入 MySQL 服务 器 的 用 户 名 ; Password 
表示 进入 MySQL 服务 器 的 密码 。 
图 设计 过 程 
连接 MySQL 服务 器 的 步骤 如 下 : 
(1) 进入 命令 提示 符 窗口 。 
(2) 如 果 MySQL 默 认 安装 在 C:\ 盘 根 目 录 下 ,在 未 设置 环境 变量 的 情况 下 , 须 在 命令 提示 符 下 进入 mysql\bin 
文件 夹 ， 输 入 命令 。 假 设 用 户 名 为 root， 密 码 为 111， 输 入 的 命令 如 下 : 
mysql —uroot -p111 
按 Enter 键 ， 输 出 如 图 8.3 所 示 的 内 容 ， 表 示 连 接 MySQL 成 功 。 
(3) 如 果 在 本 地 用 户 机 上 运行 程序 ， 可 以 直接 输入 命令 mysql -uroot -p111 来 连接 MySQL， 但 是 为 了 保证 
安全 ， 避 免 他 人 得 到 连接 MySQL 数据 库 的 密码 进行 非法 操作 ， 最 好 使 用 如 下 命令 : 
mysql -uroot -了 
并 根据 提示 输入 密码 完成 连接 ， 如 图 8.4 所 示 。 


图 8.3 连接 MySQL 成 功 图 8.4 连接 MySQL 成 功 


图 秘笈 心 法 
心 法 领悟 348: 设置 MySQL 环境 变量 。 
(1) 在 连接 MySQL 数据 库 时 ， 可 以 通过 设置 环境 变量 PATH 连接 MySQL， 这 样 一 来 用 户 无 需 手 动 进入 
MySQL 的 bin 文件 夹 ， 可 以 直接 输入 命令 连接 MySQL。 设 置 MySQL 环境 变量 的 步骤 如 下 : 
@ 右键 单 击 “ 我 的 电脑 ”图 标 ， 选 择 “属性 ”/“ 高 级 ”/“ 环 境 变量 ”命令 。 
@ 在 Administrator 的 用 户 变量 下 选择 “PATH” 变 量 ， 单 击 “ 编 辑 ”， 在 弹出 的 文本 框 中 添加 MySQL 安 
装 文件 中 bin 文件 夹 的 位 置 ， 例 如 “:C:mysqlbin”， 单 击 “ 确 定 ”按钮 ， 环 境 变 量 配 置 完毕 。 
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@ 在 命令 提示 符 下 输入 如 下 命令 : mysql -uroot -p111。 
@ 按 Enter 键 ， 输 出 如 图 8.3 所 示 的 内 容 ， 连 接 MySQL 成 功 。 


图 实例 说 明 


为 了 有 效 节省 系统 资源 ， 在 进行 MySQL 数据 库 操作 后 ， 需 要 及 时 将 MySQL 服务 关闭 。 关 闭 MySQL 服务 
的 方法 与 启动 MySQL 服务 相似 ,可 以 通过 两 种 方法 实现 。 通过 本 实例 ， 相 信用 户 会 将 关闭 MySQL 服务 器 的 两 
种 方法 熟 记 于 心 。 
图 关键 技术 


在 命令 提示 符 下 ， 输 入 命令 : 
(1) 断 开 MySQL 数据 库 连 接 。 
exit 


(2) 关闭 MySQL 服务 。 
net stop mysql 


图 设计 过 程 


(1) 在 命令 提示 符 下 ， 输 入 命令 连接 MySQL， 通 过 MySQL 数据 库 函 数 “user” 显 示 数 据 表 中 的 内 容 ， 如 
图 8.5 所 示 。 


图 8.5 查询 表 信息 
(2) 通过 命令 exit 断 开 与 MySQL 的 连接 ， 如 图 8.6 所 示 。 
(3) 输入 命令 net stop mysql， 按 Enter 键 ， 关 闭 MySQL 服务 ， 如 图 8.7 所 示 。 
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图 8.6 断 开 与 MySQL 连接 图 8.7 关闭 MySQL 服务 
图 秘笈 心 法 
心 法 领悟 349: 手动 停止 MySQL 服务。 
关闭 MySQL 服务 还 有 另外 一 种 方法 ， 即 通过 选择 “开始 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ” 命 令 ， 打 


开 Windows 服务 管理 器 ， 在 服务 列表 中 找到 “mysql” 服 务 ， 单 击 鼠标 右键 ， 从 弹出 的 快捷 菜单 中 选择 “停止 
命令 即 可 ， 如 图 8.8 所 示 。 
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图 8.8 在 Windows pp 服务 
8.2 MySQL 数据 库 


MySQL 是 一 款 安 全 、 跨 平台 、 高 效 ， 并 与 PHP、Java 等 主流 编程 语言 紧密 结合 的 数据 库 系 统 。 该 数据 库 系 
统 由 瑞典 的 MySQL AB 公司 开发 、 发 布 并 支持 ， 由 MySQL 的 初始 开发 人 员 David Axmark 和 Michael Monty 
Widenius 于 1995 年 建立 。MySQL 的 象征 符号 是 一 只 名 为 Sakila 的 海豚 ,代表 着 MySQL 数据 库 的 速度 、 能 力 、 
精确 和 优秀 本 质 。 


实例 350 


力 实例 说 明 


如 果 用 户 已 经 掌握 如 何 启动 、 连 接 、 断 开 和 关闭 MySQL 服务 ， 下 面 就 走 进 MySQL 数据 库 ， 学 习 如 何 创建 
数据 库 。 创建 数据 库 的 主要 目的 是 将 同类 的 或 者 是 同一 个 项 目 中 的 数据 表 进行 分 类 存储 , 方便 开发 人 员 查 找 和 
使 用 。 本 实例 通过 数据 库 函 数 “CREATE DATABASE” 创 建 PHP 图 书 数据 库 。 


力 关键 技术 


(1) 创建 数据 库 函 数 。 


CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name: 
CREATE DATABASE 用 于 创建 数据 库 ， 并 进行 命名 。 参 数 db_name 表示 需要 创建 的 数据 库 名 称 。 
(2) 获取 数据 库 列表 。 


SHOW {DATABASES | SCHEMAS} [LIKE ‘pattern']: 
SHOW DATABASES 可 以 列举 数据 库 名 称 。 


图 设计 过 程 


(1) 进入 命令 提示 符 窗口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 数据 库 函 数 在 命令 提示 符 下 编写 命令 ， 代 码 如 下 : 


CREATE DATABASE DB MRBOOR: 
按 Enter 键 ， 运 行 结果 如 图 8.9 所 示 。 
(3) 查看 MySQL 数据 库 列表 ， 查 找 创建 的 PHP 图 书 数据 库 是 否 存 在 ， 运 行 结果 如 图 8.10 所 示 。 
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图 8.9 创建 数据 库 db_mrbook 图 8.10 数据 库 db_mrbook 存在 于 数据 库 列 表 中 
(4) 断 开 数据 库 连 接 ， 关 闭 MySQL 服务 。 
图 秘笈 心 法 
心 法 领悟 350: 数据 库 命名 规则 。 
在 创建 数据 库 时 ， 数 据 库 命名 要 遵循 以 下 几 项 规则 。 
不 能 与 其 他 数据 库 重 名 ， 否 则 将 发 生 错 误 。 
ett 阿拉 伯 数 字 、 下 划 线 或 者 $ 组 成 ， 可 以 使 用 上 述 的 任意 字符 开头 ， 但 不 能 
使 用 单独 的 数字 ， 和 否则 会 造成 数据 库 名 与 数值 相 混淆 。 
名 称 最 长 可 为 64 个 字符 ， 而 别名 最 长 可 达 256 个 字符 。 


加 ”不 能 使 用 MySQL 关键 字 作 为 数据 库 、 表 名 。 
回 ”默认 情况 下 ，Windows 下 是 不 区 分 数据 库 名 、 表 名 的 大 小 写 的 ， 而 在 Linux 下 要 区 分 数据 库 名 、 表 名 
的 大 小 写 。 为 了 便于 数据 库 在 平台 间 进 行 移植 ， 建 议 采 用 小 写 来 定义 数据 库 名 和 表 名 。 


图 实例 说 明 

创建 数据 库 的 目的 是 向 数据 库 中 存储 同类 型 或 者 同一 个 项 目下 
的 所 有 数据 表 。 若 用 户 已 经 创建 了 数据 库 ， 需 要 通过 命令 选择 指定 
的 数据 库 ， 和 否则 计算 机 将 无 法 自动 识别 创建 的 数据 表 属 于 哪个 数据 
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库 ， 还 会 出 现 错误 提示 ， 如 图 8.11 所 示 。 图 8.11 错误 提示 
本 实例 通过 数据 库 函 数 “USE db_name” 实 现 选 择 PHP 图 书 数据 库 。 
图 关键 技术 


使 用 USE db_name 语句 可 以 通过 MySQL 把 db_name 数据 库 作为 默认 (当前) 数据 库 ， 并 应 用 于 后 续 语 句 。 
该 数据 库 保持 为 默认 数据 库 ， 直 到 语 段 的 结尾 ， 或 者 直到 发 布 一 个 不 同 的 USE 语句 ， 语 法 格式 如 下 


USE db_name; 
参数 db_name 表示 需要 使 用 的 数据 库 名 称 ， 该 名 称 必须 是 合法 的 。 
图 设计 过 程 


(1) 在 命令 提示 符 窗口 下 ， 通 过 命令 启动 MySQL 服务 ， 连 接 MySQL 服务 器 。 创 建 数据 库 并 将 此 数据 库 
命名 为 db_mrbook。 

(2) 通过 show databases; 语 句 ， 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 称 是 否 包含 用 户 指 定 的 数据 库 。 

(3) 输入 命令 use db_ mrbook:， 将 数据 库 use db_mrbook 作为 当前 默认 数据 库 ， 按 Enter 键 , 命令 窗口 将 输 
出 如 图 8.12 所 示 的 内 容 。 
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图 8.12 选择 数据 库 
(4) 关闭 数据 库 连 接 ， 关 闭 MySQL 服务 。 
图 秘笈 心 法 
心 法 领悟 351: USE 语句 的 特点 。 
使 用 USE 语句 为 一 个 特定 的 当前 的 数据 库 做 标记 ， 不 会 阻碍 访问 其 他 数据 库 中 的 表 ， 例 如 : 


use dbl; 
select * from db2.tb2; 


在 cmd 命令 提示 符 下 ， 把 数据 库 dbl 作为 当前 数据 库 标记 ， 访 问 数据 库 db2 下 表 tb2 中 所 有 的 数据 ， 这 样 
做 也 是 正确 的 。 


趣味 指数 : 南 仙 全 催 


图 实例 说 明 

若 某 个 数据 库 失 去 了 存在 的 价值 ， 那 么 为 了 节省 系统 硬盘 资源 ， 提 高 MySQL 的 运行 效率 ， 建 议 将 其 从 硬 
盘 上 加 除 。 删 除数 据 库 可 以 通过 打开 MySQL 安装 目录 ， 进 入 data 文件 夹 ， 删 除 指定 的 数据 库 文件 夹 ， 还 可 以 
通过 在 命令 提示 符 下 输入 删除 命令 。 本 实例 讲解 在 命令 提示 符 下 输入 命令 ， 实 现 删除 PHP 图 书 数据 库 。 


图 关键 技术 


DROP DATABASE 语句 用 于 删除 数据 库 中 的 所 有 表格 和 数据 库 。 使 用 此 语句 需要 获得 数据 库 DROP 权限 ， 
其 语法 格式 如 下 : 
DROP {DATABASE | SCHEMA} [IF EXISTS] db_name: 
图 设计 过 程 
(1) 进入 命令 提示 符 窗 口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 命令 语句 show databases: 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 称 是 否 存在 数据 库 
db_mrbook。 
(3) 使 用 命令 语句 use db_mrbook: 为 数据 库 db_mrbook 做 上 标记 ， 使 其 当前 默认 数据 库 ， 如 图 8.13 所 示 。 
(4) 在 命令 行 输入 drop database db_name: 语 句 ， 删 除数 据 库 的 同时 也 删除 数据 库 中 的 所 有 表 ， 所 以 在 命令 
行 输入 命令 删除 数据 库 时 ， 最 好 清查 数据 库 中 的 所 有 表 名 ， 以 防止 意外 删除 运行 程序 中 的 作用 表 而 造成 不 必要 
的 损失 。 查 看 数据 库 中 所 有 表 名 可 以 通过 命令 语句 show tables: 实 现 ， 如 图 8.14 所 示 。 
(5) 使 用 命令 行 语句 删除 PHP 图 书 数 据 库 db_mrbook， 如 图 8.15 所 示 。 
(6) 断 开 与 MySQL 服务 器 的 连接 ， 关 闭 MySQL 服务 。 
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图 8.13 选择 数据 库 图 8.14 显示 数据 库 中 的 数据 表 图 8.15 ”删除 数据 库 
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图 秘笈 心 法 

心 法 领悟 352: 屏蔽 删除 不 存在 数据 库 提 示 。 

在 命令 提示 符 窗 口中 , 输入 删除 不 存在 的 数据 库 命令 , 会 发 生 
1008 错误 ， 提 示 无 法 删除 指定 数据 库 ， 因 为 指定 数据 库 不 存在 。 
如 果 用 户 想 屏蔽 此 错误 提示 ， 可 以 使 用 数据 库 删除 语句 drop = 
database db_name: 中 的 可 选 参 数 if exists。 例 如 输入 命令 语句 po 图 8.16 删除 不 存在 数据 库 
database if exists db_name;， 则 无 论 是 否 存在 db_name 数据 库 ， - 直 提 示 操 作成 功 ， 如 图 8.16 所 示 。 


8.3 MySQL 数据 表 


创建 完 数据 库 后 ， 就 可 以 在 命令 提示 符 下 对 数据 库 进行 操作 了 ， 如 创建 数据 表 、 更 改 数据 表 结 构 以 及 删除 
数据 表 等 。 


据 库 中 创建 图 书 息 表 


图 实例 说 明 EEC 


数据 库 的 主要 作用 是 保存 数据 表 ， 而 数据 表 的 作用 是 保存 数据 
信息 。 本 实例 通过 CREATE TABLE 语句 实现 在 PHP 图 书 数据 库 中 
创建 图 书信 息 表 ， 如 图 8.17 所 示 。 


图 关键 技术 


创建 数据 表 使 用 CREATE TABLE 语句 ， 其 语法 格式 如 下 : 
CREATE TABLE table_name 

(create definition,....) 

[table_opotions] 

[select_statement] 


参数 说 明 : 

table_name: 要 创建 的 数据 表 名 。 

create_definition: 表 的 列 属性 部 分 。MySQL 要 求 创建 的 表 至 少 包含 一 列 。 

table_options: 表 的 一 些 特性 参数 。 

select statement: SELECT 语句 描述 部 分 ， 可 以 快速 地 创建 表 。 

下 面 介 绍 列 属性 部 分 ， 每 一 列 定义 的 具体 格式 如 下 ， 代 码 如 下 : 

col name type[NOT NULL | NULL][DEFAULT defanlt value][AUTO_INCREMENT][PRIMARY KEY] 

参数 说 明 : 

col name: 表示 字段 名 。 

type: 表示 字段 类 型 。 

NOT NULL 或 者 NULL: 指出 该 列 是 否 允 许 是 空 值 。 所 谓 的 空 值 是 “不 知道 ”或 “无 意义 ”的 值 ， 但 是 数 
据 “0” 和 空格 都 不 是 空 值 ， 系 统一 般 默认 允许 为 空 值 ， 所 以 当 不 允许 为 空 值 时 ， 必 须 使 用 NOT NULL。 

DEFAULT default_value: 表示 默认 值 。 

AUTO_INCREMENT: 下 全 人 本 人 号 ， 每 个 表 只 能 有 一 个 AUTO_INCREMENT 列 ， 并 且 必 须 被 索引 。 

PRIMARY KEY: 表示 是 否 为 主键 。 它 是 一 个 唯一 的 KEY， 还 有 一 个 额外 的 约束 ， 即 所 有 键 列 必须 被 定义 


图 8.17 创建 数据 表 
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为 NOT NULL。 在 MySQL 中 ， 该 列 被 命名 为 PRIMARY。 一 个 表 只 能 有 一 个 PRIMARY KEY。 如 表 中 没有 
了 PRIMARY KEY， 而 某 些 应 用 程序 需要 时 ，MySQL 将 返回 第 一 个 没有 任何 NULL 列 的 UNIQUE 键 ， 作 为 
了 PRIMARY KEY .一 个 PRIMARY KEY 可 以 是 一 个 多 列 索引 , 但 是 不 能 在 一 个 列 规格 说 明 中 使 用 PRIMARY KEY 
键 属性 来 创建 一 个 多 列 索 引 , 这 样 做 将 仅仅 标记 单个 列 作 为 主键 , 必须 使 用 PRIMARY KEY(index_col_name..…) 
句法 。 如 果 PRIMARY KEY 或 UNIQUE 键 只 由 一 个 列 组 成 ， 并 且 列 类 型 是 整 型 ， 则 可 以 用 _rowid 引用 。 

以 上 是 创建 一 个 数据 表 的 一 些 基础 知识 ， 它 看 起 来 十 分 复杂 ， 在 实际 的 应 用 中 ， 使 用 最 基本 的 格式 创建 数 
据 表 即 可 ， 具 体格 式 如 下 : 

create table table_name( 列 名 1 属性 ， 列 名 2 属性 .…) 


图 设计 过 程 
(1) 启动 MySQL 服务 ， 建 立 MySQL 服务 器 连接 。 
(2) 在 命令 提示 符 窗口 下 通过 命令 语句 create database db_name: 创 建 名 称 为 db_mrbook 的 数据 库 。 
(3) 使 用 use db_name; 语 句 设 定数 据 库 标记 。 
(4) 通过 create table tb_name0); 语 句 创建 数据 表 ， 代 码 如 下 : 
mysql> use db_mrbook; 
Database changed 
mysql> create table tb mrbook( 
-> id int(4) auto_increment prima 
-> name varchar(20) NOT NULL. 


-> pwd varchar(20) NOT NULL); 
Query OK., 0 rows affected (0.05 sec) 


(5) 断 开 MySQL 服务 器 连接 ， 结 束 MySQL 服务 。 
图 秘笈 心 法 

心 法 领悟 333: SQL 语句 格式 。 

在 输入 SQL 语句 时 ， 可 以 一 行 全 部 输出 ， 也 可 以 每 个 字段 都 换行 输出 ， 这 里 建议 用 换行 输出 ， 因 其 看 上 去 
美观 、 易 情 ， 且 在 语句 出 现 错误 时 更 容易 查找 。 


实例 354 


趣味 指数 : 会 侠 侠 侠 : 


图 实例 说 明 

查看 信息 表 分 两 种 形式 : 第 一 种 是 查看 信息 表 结构 ， 第 二 种 是 查看 信息 表 数 据 。 实 例 353 通过 create table 
tb_name; 创 建 的 只 是 表 结 构 ， 并 没有 插入 数据 信息 ， 如 果 想 查看 信息 表 数 据 信 息 ， 需 要 使 用 select 查询 语句 。 本 
实例 通过 show columns 命令 查看 信息 表 结 构 ， 运 行 结果 如 图 8.18 所 示 。 
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图 8.18 查看 信息 表 结 构图 


图 关键 技术 


使 用 show columns 命令 查看 数据 表 结 构 ， 其 语法 如 下 : 
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show [full] columns from 数据 表 名 [from 数据 库 名 ]: 
或 写成 
show [foll] columns FROM 数据 表 名 .数据 库 名 : 
设计 过 程 
(1) 开启 MySQL 服务 ， 在 命令 提示 符 窗口 输入 命令 ， 创 建 MySQL 连接 。 通 过 create database db_name; 
和 create table tb_name; 语 句 创建 数据 库 和 数据 表 。 


(2) 通过 命令 语句 show columns from tb_name: 查 看 表 结 构 ， 其 代码 如 下 : 
mysql> show columns from tb_mrbook:; 


(3) 通过 exit 和 net stop mysql; 语 句 断 开 数 据 库 服务 器 ， 并 关闭 MySQL 服务 。 
图 秘笈 心 法 


心 法 领悟 354: describe 命令 的 特点 。 


查看 数据 表 结 构 还 可 以 通过 describe 命令 。describe 命令 的 语法 格式 如 下 : 

describe 数据 表 名 ; 

其 中 ，describe 可 以 简写 成 desc。 在 查看 表 结构 时 ， 也 可 以 只 列 出 某 一 列 的 信息 ， 其 语法 格式 如 下 : 
describe 数据 表 名 列 名 ; 


实例 355 


趣味 指数 ， 斌 富 育 窗 ， 
t 


图 实例 说 明 
旺 序 员 在 建立 数据 表 时 ， 难 免 在 表 的 结 


构 上 出 现 错误 ， 例 如 
将 Date 类 型 数据 设置 为 int 类 型 ， 这 时 就 需要 更 改 表 的 结构 。 本 
实例 通过 增加 表 tb_mrbook 中 的 last_date 字段 ， 并 设置 数据 类 型 
为 Date 实现 修改 信息 表 ， 运 行 结果 如 图 8.19 所 示 。 辐 19. 夭 训 图 革 信息 表 


图 关键 技术 


修改 表 结 构 是 指 增加 或 者 删除 字段 、 修 改 字段 名 称 或 者 字段 类 型 、 设 置 取消 主键 外 键 、 设 置 取消 索引 以 及 
修改 表 的 注释 等 。 修 改 表 结构 采用 alter table 命令 ， 其 语法 如 下 : 

alter [IGNORE] table 数据 表 名 alter_spec[.alter_ spec]…: 

注意 ， 当 指定 IGNORE 时 ， 如 果 出 现 重复 的 行 ， 则 只 执行 一 行 ， 其 他 重复 的 行 被 删除 。 其 中 ，alter_spec 
子 句 定义 要 修改 的 内 容 ， 其 语法 如 下 : 


alter_specification: 


ADD [COLUMN] create_definition [FIRST | AFTER column name ] -添加 新 字段 

| ADD INDEX [index_name] (index_col name,...) -添加 索引 名 称 
| ADD PRIMARY KEY (index_col name,...) ~ 添加 主键 名 称 
| ADD UNIQUE [index_name] (index_col name,...) 一 添加 唯一 索引 
| ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT} ”-- 修 改 字段 名 称 
| CHANGE [COLUMN] old_col name create_definition 一 修改 字段 类 型 
| MODIFY [COLUMN] create_definition 一 修改 子 句 定义 字段 
| DROP [COLUMN] col name 一 删除 字段 名 称 
| DROP PRIMARY KEY 一 删除 主键 名 称 
| DROP INDEX index name -删除 索引 名 称 
| RENAME [AS]new tbl name 一 更 改 表 名 

| table_options 
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设计 过 程 
(1) 开启 MySQL 服务 器 ， 在 命令 提示 符 窗口 下 创建 MySQL 连接 。 通 过 create database db_ name; 和 create 
table tb name; 语 名 创建 数据 库 和 数据 表 。 


(2) 使 用 命令 语句 show columns from tb_name: 查 看 表 结构 。 
(3) 在 命令 提示 符 下 输入 如 下 命令 : 


mysql> alter table tb mrbook add last_date Date; 
按 Enter 键 ， 运 行 结果 如 图 8.19 所 示 。 
(4) 通过 exit 和 net stop mysql; 语 句 断 开 数 据 库 服务 器 并 关闭 MySQL 服务 。 


图 秘笈 心 法 


心 法 领悟 355: alter table 语句 的 特点 。 
alter table 语句 允许 指定 多 个 动作 ， 其 动作 间 使 用 逗号 分 隔 ， 每 个 动作 表示 对 表 的 一 个 修改 。 


趣味 指数 : 南 页 仙 页 


图 实例 说 明 


MySQL 数据 表 是 不 允许 重 命名 的 ， 所 以 在 同一 个 数据 库 中 绝 


对 不 会 出 现 两 个 名 称 相 同 的 表 , 但 是 一 般 情况 下 , 程序 员 希 望 自己 
创建 的 数据 表 更 能 贴近 自己 的 项 目 ,所 以 对 数据 表 重 命名 有 时 是 不 ”加 
可 避免 的 本 实例 通过 rename table 命 令 实现 对 图 书信 息 表 重 命名 ， 图 8.20 重 命 名 图 书信 息 表 
运行 结果 如 图 8.20 所 示 。 


图 关键 技术 


重 命名 数据 表 采 用 rename table 命令 ， 语 法 格式 如 下 : 
rename table 数据 表 名 1 To 数据 表 名 2; 


或 者 
alter table 数据 表 名 1 rename 数据 表 名 2; 
图 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 器 服务 ， 连 接 MySQL 数据 库 ， 创 建 数据 库 并 建立 数据 表 。 
(2) 使 用 命令 语句 show tables; 显 示 当 前 数据 库 中 的 所 有 表 。 
(3) 在 命令 提示 符 下 输入 如 下 命令 : 


mysql> alter table tb_mrbook rename tb_mrbook _php: 
按 Enter 键 ， 完 成 数据 表 的 重 命名 操作 ， 运 行 结 果 如 图 8.20 所 示 。 
(4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


图 秘笈 心 法 
心 法 领悟 356: rename 语句 特点 。 


使 用 “rename table 数据 表 名 1 To 数据 表 名 2” 语 句 可 以 同时 对 多 个 数据 表 进行 重 命名 ， 多 个 表 之 问 以 过 
号 “,” 分 隔 。 
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实例 357 


趣味 指数 : 南 二 二 全 


图 实例 说 明 


使 用 drop database db _ name: 语句 删除 数据 库 的 同时 会 连带 删除 
数据 库 中 的 所 有 数据 表 ， 如 果 只 想 删除 数据 库 中 的 某 个 表 而 保留 其 
他 所 有 表 ， 显 然 此 语句 已 经 不 再 适用 。 删 除数 据 库 中 某 个 数据 表 可 
以 使 用 drop table tb_name: 语 句 ， 运 行 结果 如 图 8.21 所 示 。 


图 关键 技术 
删除 数据 表 的 操作 很 简单 ， 同 删除 数据 库 的 操作 类 似 ， 使 用 drop table 命令 就 可 以 实现 ， 其 语法 格式 如 下 : 
drop table 数据 表 名 ; 

图 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 输入 命令 连接 到 MySQL 服务 器 。 

(2) 使 用 命令 语句 show tables; 显 示 当 前 数据 库 中 的 所 有 表 。 
(3) 在 命令 提示 符 下 输入 如 下 命令 ， 删 除 指定 数据 表 。 


drop table tb_mrbook; 
按 Enter 键 ， 运 行 结果 如 图 8.21 所 示 。 
(4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 
秘笈 心 法 
心 法 领悟 3537: 屏蔽 删除 不 存在 数据 表 的 错误 提示 。 
在 删除 数据 表 的 过 程 中 ， 如 果 删 除 一 个 不 存在 的 表 将 会 产生 错误 ， 这 时 在 删除 语句 中 加 入 fexists 关键 字 ， 


就 不 会 出 错 ， 其 语法 格式 如 下 
drop table if exists 数据 表 名 ; 


图 8.21 删除 数据 库 中 指定 数据 表 


8.4 MySQL 数据 


前 面 介 绍 了 对 数据 库 和 数据 表 的 操作 ， 它 们 是 包含 与 被 包含 的 关系 ， 即 数据 库 包含 数据 表 ， 数 据 表 被 包含 
于 数据 库 。 而 数据 表 中 包含 数据 ， 在 MySQL 数据 库 中 真正 被 调用 的 是 某 个 数据 库 中 数据 表 里 面 的 数据 ， 因 此 
如 何 更 好 地 操作 和 使 用 这 些 数据 才 是 使 用 MySQL 数据 库 的 根本 。 


实例 358 


力 实例 说 明 

建立 数据 库 是 为 了 把 不 同类 型 或 者 不 同 要 求 的 数据 分 类 存储 在 不 同 的 数据 表 中 ， 即 创建 数据 表 是 为 了 将 相 
类 型 或 者 相同 要 求 的 数据 存储 在 同一 表 中 。 本 实例 讲解 通过 SQL 语句 向 图 书信 息 表 中 添加 数据 ， 运 行 结果 如 
导 8.22 所 示 。 


殉 本 
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czvrrmowsvsrsteaozvexdexe - raal uroot EE 


图 8.22 向 图 书信 息 表 中 添加 数据 


力 关键 技术 


建立 一 个 空 的 数据 表 时 ， 首 先 要 想到 的 就 是 如 何 向 数据 表 中 添加 数据 。 这 项 操作 可 以 通过 insert 命令 来 实 
现 。insert 语句 的 语法 如 下 : 
insert into 数据 表 名 (column_name,column_name2, … ) values (valuel, value2，… ); 
设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 命令 行 语句 连接 MySQL 服务 器 ， 创 建 数据 库 并 建立 数 
据 表 。 
(2) 编辑 insert 语句 ， 执 行 数据 的 添加 操作 ， 其 代码 如 下 : 
insert into tb_mrbook_php(id,name,pwd,last_date)values (",'lizhonghua','5315',nowO); 
(3) 当 提 示 符 窗口 出 现 如 图 8.23 所 示 的 内 容 时 ， 表 示 数 据 添加 成 功 。 


二 选 定 C: WINDOYS\systenI2\ 


图 8.23 数据 添加 成 功 


(4) 通过 select 语句 查询 数据 表 中 内 容 ， 显 示 结 果 如 图 8.22 所 示 。 
(5) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 
图 秘笈 心 法 
心 法 领悟 338: insert 语句 的 特点 。 
在 MySQL 中 ， 一 次 可 以 同时 插入 多 行 记录 ， 各 行 记 录 的 值 在 values 关键 字 后 以 逗号 “,” 分 隔 ， 而 标准 的 
SQL 语句 一 次 只 能 插入 一 行 。 


高 级 
趣味 指数 : 商 俩 耸 窗 ; 


力 实例 说 明 


用 户 向 数据 表 中 插入 数据 信息 时 ， 若 在 手动 输入 过 程 中 出 现 错误 ， 就 需要 使 用 SQL 语句 对 错误 的 数据 进行 
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修改 。 本 实例 通过 修改 语句 ， 修 改 图 书信 息 表 中 操作 数据 表 的 时 间 ， 运 行 结果 如 图 8.24 所 示 。 


四 修改 后 数据 


图 8.24 修改 图 书信 息 表 


力 关键 技术 
， 该 语句 的 语法 格式 如 下 : 


执行 修改 操作 应 用 的 是 update 命令 
update 数据 表 名 set column_name =new_valuel,column_name2 = new_value2, ……where condition 
其 中 ，set 子 句 指出 要 修改 的 列 及 其 给 定 的 值 ，where 子 句 是 可 选 的 ， 如 果 给 出 该 子 句 将 指定 记录 中 哪 


应 该 被 更 新 ， 否 则 ， 所 有 的 记录 行 都 将 被 更 新 。 
图 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 命令 行 语句 连接 MySQL 服务 器 ， 创 建 数 据 库 并 建立 数 


息 表 ， 如 图 8.24 中 @ 原 数据 表 所 示 。 
数据 ， 其 代码 如 下 : 


村 


- 行 


据 表 。 


(2) 使 用 select 查询 语句 查询 图 书信 
(3) 使 用 update 更 新 语句 更 新 数据 表 中 


update tb_mrbook_php set last_date=2010-07-11' where 
(4) 当 提 示 符 窗口 出 现 如 图 8.25 所 示 的 内 容 时 ， 表 示 数 据 更 新 成 功 。 


图 8.25 修改 成 功 提示 


Ph@ 修 改 后 数据 所 示 。 


(5) 通过 select 语句 查询 数据 表 中 的 内 容 ， 显 示 结果 如 图 8.24 中 
F MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


(6) 断 天 
图 秘笈 心 法 
心 法 领悟 359: 使 用 where 子 句 的 注意 事项 。 
- 旦 where 子 句 出 错 ， 有 可 能 会 破坏 所 有 的 数据 信息 。 


- 定 要 保证 where 子 句 的 正确 性 ， 


修改 数据 信息 时 
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实例 360 


趣味 指数， 请 商户 商 : 


力 实例 说 明 

市 除数 据 表 中 的 所 有 数据 在 实际 开发 中 是 不 多 见 的 ， 删 除数 据 表 中 的 所 有 数据 意味 着 清空 数据 表 中 的 所 有 
信息 ， 如 果 是 操作 上 的 失误 造成 数据 表 中 所 有 信息 丢失 ， 对 于 程序 员 来 说 是 灾难 性 的 ， 所 以 对 数据 表 中 信息 
的 删除 操作 需要 十 分 谨慎 。 本 实例 通过 两 种 方法 实现 删除 图 书信 息 表 中 所 有 数据 ， 运 行 结 果 如 图 8.26 和 图 8.27 
所 示 。 


8.26 清空 数据 库 图 8.27 delete 语句 删除 信息 


图 关键 技术 


(1) 使 用 delete 语句 删除 数据 信息 ， 其 语法 如 下 : 
DELETE [LOW PRIORITY] [QUICK] [IGNORE] FROM tbl name 
RE where_definition] 
[ORDER BY ..] 
[LIMIT row_count] 
该 语句 在 执行 过 程 中 ， 删 除 tbl_name 表 中 的 记录 ， 如 果 没 有 指定 where 条 件 ， 将 删除 所 有 的 记录 ; 如 果 指 
定 WHERE 条 件 ， 将 按照 指定 的 条 件 进行 删除 。 参 数 ORDER BY 表示 按 条 件 排序 ， 参 数 LIMIT row_count 表示 
控制 显示 条 数 。 
(2) 使 用 truncate 语句 清空 数据 表 信 息 ， 其 语法 如 下 : 
TRUNCATE [TABLE] tb_name; 


用 于 完全 清空 数据 表 ， 从 逻辑 上 说 ， 该 语句 与 用 于 删除 所 有 行 的 delete 语句 等 同 。 
图 设计 过 程 
(1) 开启 MySQL 服务 ， 通 过 命令 提示 符 窗口 创建 MySQL 连接 ， 新 建 数据 库 和 数据 表 ， 将 数据 表 命名 为 


tb_nubook， 利 用 INSERT 插入 语句 向 数据 表 中 插入 数据 ， 并 通过 select 语句 查询 数据 表 。 
(2) 利用 tnmeate 语句 ， 清 空 数据 表 中 所 有 数据 ， 其 代码 如 下 : 


truncate tb_mrbook: 
运行 结果 如 图 8.26 所 示 。 
(3) 利用 delete 语句 删除 所 有 数据 ， 其 代码 如 下 : 


delete from tb_mrbook; 

运行 结果 如 图 8.27 所 示 。 
图 秘笈 心 法 

心 法 领悟 360: 按 这 删除 数据 。 

在 实际 的 应 用 中 ， 在 执行 删除 操作 时 ， 执 行 删除 的 条 件 一 般 应 该 为 数据 的 id4， 而 不 是 具体 某 个 字段 值 ， 这 
样 可 以 避免 一 些 不 必要 的 错误 发 生 。 
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实例 361 趣味 指数 : 妇 二 页 走 


图 实例 说 明 


删除 图 书信 息 表 中 的 所 有 数据 或 者 说 清空 数据 表 的 方法 在 实际 
编程 中 是 很 少见 的 ， 一 般 都 是 删除 指定 的 一 条 或 几 条 数据 。 本 实例 通 
过 delete 语句 的 子 句 实现 删除 图 书信 息 表 中 的 指定 数据 ， 运 行 结果 如 
图 8.28 所 示 。 


图 关键 技术 


本 实例 的 关键 点 是 where 条 件 句 的 灵活 运用 。where 子 句 用 要 检索 的 记录 。 因 为 一 个 表 通 常会 有 数 
千 条 记录 ， 在 查询 结果 中 ， 用 户 仅 需 其 中 的 一 部 分 记录 ， 这 时 就 需要 使 用 Where 子 句 指定 一 系列 的 查询 条 件 。 
下 面 是 where 子 句 最 简单 的 语法 : 

SELECT< 字 段 列表 > 

FROM< 表 名 > 

WHERE< 条 件 表达 式 > 


为 了 满足 多 种 不 同 的 查询 ，where 子 句 提供 了 丰富 的 搜索 条 件 ， 下 面 将 给 出 where 子 句 常用 的 比较 运算 符 ， 
如 表 8.1 所 示 。 


表 8.1 where 子 句 常用 的 比较 运算 符 


图 8.28 指定 删除 id 等 于 5 的 数据 


运 算 符 说 了 明 
= 等 于 
二 
< 小 于 
= 大 于 等 于 
<= 小 于 等 于 
不 大 于 
国 不 小 于 
二 或 = 不 等 于 

图 设计 过 程 


(1) 开启 MySQL 服务 ， 输 入 命令 连接 MySQL 服务 器 ， 创 建 数 
据 库 和 数据 表 ， 将 数据 表 命 名 为 tb_mrbook， 并 通过 insert 语句 向 数 
据 表 里 添加 信息 ， 通 过 select 语句 查看 表 信 息 。 


(2) 通过 delete 语句 删除 id 等 于 5 的 数据 ， 运 行 结果 如 图 8.29 图 8.29 删除 成 功 提示 
所 示 。 
图 秘笈 心 法 


心 法 领悟 361: where 子 句 的 优点 。 
where 子 句 是 非常 灵活 的 ， 其 使 用 方法 与 PHP 中 if0 语 句 有 些 类 似 ， 也 可 以 用 于 执行 比较 或 逻辑 运算 。 
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8.5 PHP 操作 MySQL 数据库 


PHP 支持 的 数据 库 类 型 较 多 ， 在 这 些 数据 库 中 ，MySQL 数据 库 与 PHP 结合 最 好 ， 与 Linux 系统 、Apache 
服务 器 和 PHP 语言 构成 当今 主流 的 LAMP 网 站 架构 模式 ， 并 且 PHP 提供 多 种 操作 MySQL 数据 库 的 方式 ， 因 
而 适合 不 同 需求 和 不 同类 型 项 目的 需要 。 


高 级 | 
要 可 煞 ， 机 页 页 


图 实例 说 明 


通过 PHP 语言 连接 MySQL 数据 库 与 在 cmd 命令 提示 符 下 操作 数据 库 有 所 不 同 。 例 如 ， 设 置 页 面 的 编码 格 
式 为 GBK, 在 MySQL 命 令 提示 符 下 只 需 输 入 set names gbk 即 可 ,而 在 PHP 中 需 使 用 函数 mysql_query(“set names 
GBK”) 实 现 。 所 以 用 户 在 学 习 操 作 MySQL 数据 库 的 同时 还 要 与 PHP 函数 联合 应 用 , 下面 就 为 用 户 讲解 使 用 PHP 
操作 MySQL 数据 库 。 本 实例 通过 mysql_connect0 函 数 连接 MySQL 服务 器 ， 运 行 结果 如 图 8.30 所 示 。 


连接 MySQL 服 务 器 


mms llocahost mor oot mn leee 


图 8.30 连接 MySQL 服务 器 


力 关键 技术 


使 用 mysql_connectO 函 数 打 开 一 个 到 MySQL 服务 器 的 连接 ， 其 语法 如 下 : 

Tesource mysql_connect ( [string server [, string usemame [. string password [. bool new_link [, int client_flags]]]]] ): 
参数 说 明 : 

string server: 表示 连接 数据 库 的 HOST。 

string username: 表示 MYSQL 数据 库 用 户 名 。 

string password: 表示 MySQL 数据 库 密码 。 


图 设计 过 程 
新 建 index.php 文件 ， 创 建 form 表单 提交 连接 MySQL 服务 器 的 用 户 名 、 密 码 和 服务 器 。 获 取 form 表单 提 
2 应 用 mysql_connect0 函 数 完成 与 MySQL 服务 器 的 连接 ， 其 代码 如 下 : 


ifs 1 人 / 单 击 “ 确 定 ” 按 钮 
这 $_POST[na] 一 "| $_POST[nam] — "" || $ POST[name] —""){ /检测 文本 框 是 否 为 空 
echo "<scriptf>alert( 文 本 框 不 能 为 室 ):</scripf>”: /有 输出 提示 
jelsef 
if(@mysql connect("$ POST[na]"."$_POST[nam]"."$ POST[name] )){ // 连 接 MySQL 服务 器 
echo "<script>alert( 连 接 MySQL 服务 器 成 功 ):</script>"; /输出 提示 
jelsef 
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echo "<script>alert( 错 误 了 ");</script>"; 
} 


上 
中 


图 秘笈 心 法 
心 法 领悟 362: 连接 MySQL 服务 器 。 


安装 MySQL 数据 库 时 ， 会 提示 用 户 设置 Host、 用 户 名 和 密码 。 如 果 用 户 并 未 进行 设置 ，MySQL 在 默认 安 
装 的 情况 下 ，Host 为 localhost、 用 户 名 为 root、 密 码 为 NULL ( 空 ) 。 


数 选择 MySQL 数据 库 


高 级 : 


趣味 指数 : 催 俩 催 商 | 


实例 363 


力 实例 说 明 


通过 函数 mysql_connect0 可 以 与 MySQL 服务 器 建立 连接 ， 在 cmd 命令 提示 符 下 使 用 use 语句 选择 想 要 操 
作 的 数据 库 。 在 PHP 代码 中 需要 使 用 函数 mysql_select_ db0 选 择 并 连接 数据 库 。 本 实例 通过 函数 mysql_select_db0 
实现 与 MySQL 数据 库 的 选择 与 连接 ， 运 行 结果 如 图 8.31 所 示 。 


rr 3 


8.31 使 用 函数 选择 并 连接 MySQL 数据 库 


图 关键 技术 


mysql_select_db0 函 数 ， 用 于 选择 MySQL 数据 库 。 
bool mysql_select_db ( string database_name [, resource link_identifier] ); 
参数 说 明 : 

string database_name: 表示 选择 MySQL 数据 库 名 称 。 
resource link identifier， 表示 MySQL 连接 标识 。 


力 设计 过 程 
(1) 新 建 index.php 文件 。 首 先 连 接 MySQL 服务 器 ， 通 过 mysql 函数 库 的 函数 读 取 输出 MySQL 数据 库 中 
存储 的 数据 库 名 称 ， 并 且 通 过 下 拉 列 表 框 显示 所 有 数据 库 名 称 ， 代 码 如 下 : 
<?php 


Sconn = mysql_connect("localhost","root","111"); /连接 MySQL 服务 器 
Srs = mysql_query("show databases"); /查询 操作 
while(Srst = mysql_fetch_array(Srs)){ /while 循环 

$a=0; 

echo "<option value=".$rst[$a].">".$rst[$a]."</option><br>"; /输出 数据 库 名 称 

Satt; 


} 


> 
(2) 当 单 击 “确定 ” 按 钮 时 ， 将 下 拉 列 表 框 的 选择 信息 以 参数 的 形式 传递 给 函数 mysql select db0， 并 输 
出 提示 信息 ， 其 代码 如 下 : 
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这 $_ POST[sub]){ /通过 POST 方式 传递 参数 
这 $_POST[select — "1"){ /当下 拉 列 表 框 值 为 1 时 
echo "<script>alert( 请 选择 数据 库 "):</script>"; /输出 提示 信息 
jelsef 
这 mysql_select CR POST[select]".Sconn)){ // 如 果 不 为 1， 连 接 数据 库 
mysql_close(): /| 关闭 连接 
echo "<seripP>alert( 已 选择 指定 数据 库 9: :</script>"; /输出 提示 
Jelse{ 
echo "<script>alert(' 出 错误 了 "):</script>"; /提示 信息 
外 
> 
秘笈 心 法 


心 法 领悟 363: 两 种 方法 判断 数据 库 是 否 连接 成 功 。 
本 实例 是 利用 函数 mysql_select_ db0 的 返回 值 ， 判 断 是 否 连接 到 数据 库 从 而 输出 提示 信息 。 还 可 以 通过 函数 
Imysql_select db0 or die0 来 判断 是 否 连 接 到 数据 库 , 如 果 连 接 到 数据 库 将 不 会 有 任何 信息 提示 , 否则 输出 错误 信息 。 
高 级 
趣味 指数 : Bd | 


图 实例 说 明 

用 PHP 代码 操作 MySQL 数据 库 的 主要 目的 是 为 了 让 程序 控制 数据 库 信 息 的 增删 改 查 等 操作 ， 而 函数 
mysql_queryO 可 以 看 作 是 部 分 SQL 语句 的 载体 。 本 实例 通过 mysql_query0 函 数 执行 SQL 语句 ， 和 运行 结果 如 
图 8.32 所 示 。 


8.32 ”mysql_query0 函 数 执行 SQL 语句 


图 关键 技术 


使 用 mysql_queryO 函 数 可 向 与 指定 的 连接 标识 符 关联 的 服务 器 中 当前 活动 的 数据 库 发 送 一 条 MySQL 查询 ， 
其 语法 如 下 : 

Tesource mysql_query ( string query [, resource link_identifier] ): 

参数 说 明 : 

resource link identifier:， 连接 标识 。 

string query: SQL 语句 。 


图 设计 过 程 
新 建 index.php 文件 。 首 先 连接 服务 器 ， 连 接 db_database08 数据 库 。 然 后 ， 获 取 form 表单 中 提交 的 SQL 
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语句 ， 并 且 对 SQL 语句 的 类 型 进行 判断 ， 根 据 不 同 的 类 型 应 用 mysql_ query0 函 数 执行 不 同 的 操作 ， 其 关键 代码 


如 下 了 
if($_POST[sub) { // 单 击 按钮 
$sql = $_POST[text]; /定义 变量 
if($sq 一 ""){f /如 果 文 本 框 为 室 
echo "<script>alert(' 您 输入 的 文本 框 内 容 为 宝 ):</script>"; //JavaScript 提示 
jelsef 
$conn = mysql_connect("localhost","root",."111") or die(" 连 接 MySQL 出 现 错 误 "); /连接 MySQL 
mysql_select_db("db_database08",Sconn) or die("false"); // 连 接 数 据 库 
$sqll = substr($sql.0,6); /截取 SQL 语句 前 6 个 字符 
if(strtoupper($sqll) 一 "SELECT"){ 
这 mysql_ query($sqD){ // 执 行 查询 操作 
echo "<script>alert( 您 在 执行 查询 操作 "):</script>"; 
jelsef 


echo "<script>alert(SQL 语句 出 现 错误 ):</script>"; 
} 
jelsef 
这 strtoupper(Ssql1) — "INSERT"){ 
这 mysql_query(SsqD){ 
echo "<script>alert( 您 在 执行 插入 操作 "):</script>"; 
jelsef 
echo "<script>alert('SQL 语句 出 现 错误 );</script>"; 
} 
jelse{ 
这 strtoupper(Ssqll) — "UPDATE"){ 
这 mysql_query(SsqD)f 
echo "<script>alert( 您 在 更 新 查询 操作 "):</script>"; 
jelsef 
echo "<script>alert(SQL 语句 出 现 错误 );</script>"; 
} 


} 
} 

本 

在 对 SQL 语句 的 类 型 进行 判断 时 ， 首 先 应 用 substr0 函 数 截取 SQL 语句 的 前 6 个 字 节 ， 然 后 将 截取 的 内 容 
转换 为 小 写 ， 并 通过 这 6 个 字符 串 对 SQL 语句 的 类 型 进行 判断 。 
图 秘笈 心 法 

心 法 领悟 364: mysql_query0 中 连接 标识 符 的 作用 。 

mysql_ query0O 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 当前 活动 的 数据 库 发 送 一 条 查询 。 如 果 没 有 指定 
link_identifier， 则 使 用 上 一 个 打开 的 连接 ， 如 果 没 有 打开 的 连接 ， 本 函数 会 尝试 无 参数 调用 mysql_connect0 函 
数 来 建立 一 个 连接 并 使 用 ， 其 查询 结果 会 被 缓存 。. 


实例 365 


力 实例 说 明 

用 户 在 进行 查询 操作 时 ， 目 的 是 为 了 将 结果 显示 到 网 页 中 ， 下 面 介绍 如 何 通过 mysql_fetch_array0 函 数 将 查 
询 结果 返回 到 数组 中 。 本 实例 通过 函数 mysql fetch_array0 将 查询 结果 返回 到 数组 中 ， 打 印 数 组 的 结果 如 图 8.33 
启示， 循环 输 出 数组 中 数据 的 结果 如 图 8.34 所 示 。 


497 


lmrrsof[3] => 2010-07 
[Array ( [0]=> 2 [d] = 
2010-07-13 [last_dat 
[Array ( [0: 
2010-07-13 [last_date] 
[Array ( [0]=> 4 [i 
2010-07-13 llast_date] => 2010-07-13) 


026 [pwa] —> 1026 13] 一 


=> 小 刘 [name] => 小 刘 [2]=> 1015 [pwd]=> 1015 [3] => 


8.33 打印 数组 


图 关键 技术 


Ly 

1 明日 科技 mrsoft 2010-07-13 

2 小 杨 1081 2010-07-13 

3 小 证 1026 2010-07-13 

4 小 刘 1015 2010-07-13 
图 8.34 打印 表格 


mysql_fetch_array0 函 数 用 于 从 结果 集中 取得 一 行 作 为 关联 数组 或 数字 数组 ， 或 二 者 兼 有 ， 其 语法 如 下 : 


array mysql_fetch_array ( resource result [, int result_type] ); 


参数 resource result 为 结果 集 。 


设计 过 程 


(1) 创建 PHP 脚本 文件 ， 命 名 为 nphp， 将 MySQL 数据 库 的 连接 操作 封装 到 类 中 ， 定 义 构造 函数 为 成 员 
变量 赋值 ， 定 义 connectO 函 数 实现 与 MySQL 服务 器 和 数据 库 的 连接 。MySQL 类 的 代码 如 下 : 


<?php 
class mysql{ 


function 。 construct(ShostSusermname.Spwd.Sdb){f 
Sthis -> host = $host; 
Sthis -> usemame = $usermame; 
Sthis -> pwd = Spwd; 
Sthis -> db = $db; 
Sthis -> connectO; 


. 
function connectO{ 
Sthis -> conn = $conn; 


Sthis -> conn = mysql_connect($this -> host,$this -> username. S$this -> pwd): 


mysql_select_db($this -> db.$this -> conn): 
mysql_query("SET NAMES UTF8"); 


} 
> 


1/ 为 成 员 变量 赋值 


/定义 连接 标识 
/连接 数据 库 服务 器 
/连接 数据 库 
/设置 数据 库 编码 


(2) 创建 PHP 脚本 文件 ， 命 名 为 index.php。 首 先 ， 包 含 数据 库 连 接 类 文件 。 然 后 ， 执 行 类 的 实例 化 操作 ， 
完成 与 数据 库 的 连接 ， 并 返回 连接 对 象 。 最后， 定义 SQL 查询 语句 ， 通 过 mysql_query0 函 数 执行 查询 操作 ， 通 
过 mysql_fetch_array0 函 数 将 查询 结果 集 存储 到 数组 中 ， 并 通过 while 语句 循环 输出 查询 结果 集中 的 数据 ， 其 代 


人 码 如 下 : 
<?php 
if(s$_GET[ara] 一 "19{ 
include("in php"); 


$my =new mysql("localhost","root"."111","db_database08"): 


$sql = "select * from tb_020"; 

Srs= mysql_query($sql); 

while(Srst = mysql fetch array($rs){ 
Print_r(Srst): 

} 


} 
if($_GET[table] — "1"){ 
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/如 果 地 址 栏 参数 arra 等 于 1 
/包含 数据 库 连接 类 
/实例 化 数据 库 连接 类 

/sql 语 名 

/执行 查询 操作 并 返回 结果 集 
/循环 数组 

/打印 数组 


/如 果 地 址 栏 参数 table 等 于 1 
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include("in.php"); // 包 含 数据 库 连 接 类 
$my =new mysql("localhost","root"."111","db_database08"); /实例 化 对 象 
$sql = "select * from tb_020"; /sql 语句 
Srs= mysql_query($sql); /返回 结果 集 
> 
<table border="1" bordercolor="#FFCC00" cellspacing="0px" width="580px"> 
<tr><td>ID</td><td> 用 户 名 </td><td> 密 码 </td><td> 时 间 <Jtd></tr> 
while(Srst = mysql_fetch_array($rs){ /循环 数组 
echo "<tr>"; 
本 "<td>".Srst[0]."</td><td>".Srst[1]."<htd><td>"Srst[2]."</td><td>"Srst[3]."</td>"， /表格 式 输出 
echo “</tr>"; 
> 
</table> 
<?php 
> 
图 秘笈 心 法 


心 法 领悟 365: 使 用 mysql_fetch_array0 函 数 的 注意 事项 。 
在 使 用 mysql_fetch_array0 函 数 时 ， 如 果 结 果 中 的 两 个 或 以 上 的 列 具 有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访 
问 同名 的 其 他 列 ， 必 须 用 该 列 的 数字 索引 或 给 该 列 起 个 别名 ， 对 有 别名 的 列 ， 不 能 再 用 原来 的 列 名 访问 其 内 容 。 


函数 从 结果 集中 获取 数据 高 级 
力 实例 说 明 


趣味 指数 : 食 食 信贷 | 
获取 查询 结果 集中 数据 信息 的 函数 很 多 ， 下 面 推荐 一 个 新 的 获取 结果 集中 数据 的 函数 一 一 mysql_fetch row0。 
本 实例 的 运行 结果 如 图 8.35 所 示 。 


mysql fetch_row() 国 数 96 


从 结 黑 筑 中 获取 数据 
查 询 | 于 一 粤 
D 用 名 密友 晤 问 
1 小 惕 1081 2010-07-14 


图 8.35 查询 一 条 数据 


图 关键 技术 


mysql_fetch_row0 函 数 用 于 从 结果 集中 获取 一 行 作为 枚 举 数组 , 返回 根据 所 获取 的 行 生成 的 数组 ,如果 没有 
更 多 行 则 返回 FALSE， 其 语法 如 下 : 
array mysql ftch_ row ( resource result ): 


参数 result 为 指定 的 结果 集 。 
图 设计 过 程 


(1) 新 建 inphp 文件 ， 封 装 数据 库 的 连接 类 。 

(2) 新 建 index.php 文件 。 首 先 ， 包 含 数 据 库 连接 类 文件 。 然 后 ， 执 行 类 的 实例 化 操作 ， 完 成 与 数据 库 的 
连接 ， 并 返回 连接 对 象 。 最 后 ， 通 过 mysql fetch rowO 函 数 将 查询 结果 集 存 储 到 数组 中 ， 并 输出 获取 到 的 数据 ， 
其 代码 如 下 : 
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<?php 
include ("in.php"); 
Smy = new mysql ( "localhost", "root", "111", "db database08" ): 
if($_GET[id]—D){ 
$sql = "select * from tb_demo021"; 
Srs = mysql query ( $sql ); 
Srst =mysql fetch row ( Srs ); 
Ms: 
<?php 
echo "<tr><td class='one'’>" . $rst [0] . "</td><td class='one>" . Srst [1] . "</td><td class='one>" . $rst [2] . "</td><td class=one>" . $rst [3] . 
"</td></tr>"; 


} 

/ 悍 击 “下 一 条 ”按钮 ， 类 似 分 页 

if($_GET [id] —2) { 
$os = mysql_query ( "select * from tb_demo021_order order by id desc limit 1" ); 
S$ost = mysql fetch row ($0s); 


S$id = $ost [1]; 
S$rs = mysql_query ( "select * from tb_demo021 limit $id,1" ); 
$id= $id+ 1; 
Srst = mysql_fetch row ( $rs); 

> 

岂 笈 心 法 


心 法 领悟 366: mysql_fetch_ row0 函 数 的 特点 。 

mysql_fetch_row0 函 数 是 从 指定 的 结果 标识 关联 的 结果 集中 取得 一 行 数据 并 作为 数组 返回 ,每 个 结果 的 列 储 
存在 一 个 数组 的 单元 中 ， 偏 移 量 从 0 开始 。 依次 调用 mysql_fetch_row0 函 数 将 返回 结果 集中 的 下 一 行 ， 如 果 
没有 更 多 行 则 返回 FALSE。 


函数 获取 结果 集中 记录 数 高 级 
趣味 指数 : 例会 会 会 | 


力 实例 说 明 


本 实例 介绍 如 何 通过 PHP 的 函数 mysql_num rowsO 统 计数 据 库 中 的 记录 数 ， 运 行 结果 如 图 8.36 所 示 。 


mysal num_rowsO®R 


洲 取 数 其 库 。 效 取 数 卢 赤 效 取 信息 


Li 用 户 室 码 
小 杨 1081 
2 小 光 102 
bE 个 刘 1018 2010-07-14 
当 而 共有 数据 表 池 个 


图 8.36 tb_demo021 下 的 信息 数量 


图 关键 技术 
mysql_num rows0 函 数 ， 用 于 取得 结果 集中 行 的 数目 。 


int mysql_num rows ( resource result ): 


参数 result 指定 操作 的 结果 集 ， 其 返回 值 为 mt 类 型 。 
图 设计 过 程 
(1) 新 建 nphp 文件 ， 封 装 数据 库 的 连接 类 。 
(2) 新 建 index.php 文件 。 首 先 ， 包 含 数 据 库 连接 类 文件 。 然 后 ， 执 行 类 的 实例 化 操作 ， 完 成 与 数据 库 的 
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连接 ， 并 返回 连接 对 象 。 最后， 通过 mysql num rows0 函 数 统计 数据 库 、 数 据 表 的 个 数 以 及 指定 数据 表 的 总 记 
录 数 ， 其 关键 代码 如 下 : 


<?php 
include ("inphp 
Smy = new mysql ( "localhost", "root", "111", "db database08" ); 
if($_GET[id] =—1){ 

Srs= mysql_query ( "show databases" ); 

$num = mysql num rows ( $rs ): 

while ( Srst= mysql_fetch row (S$rs)) { 

Print r ( Srst ); 


echo "<br><b class=two> 当 前 共有 数据 库 <b class='three>" . Snum . "</b> 个 </b>"; 


E 


} 
上 述 代码 查询 MySQL 数据 库 中 包含 的 数据 库 ， 通 过 mysql_num rows0 函 数 统计 数据 库 的 个 数 ， 应 用 while 
语句 循环 输出 数据 库 的 名 称 。 


图 秘笈 心 法 


心 法 领悟 367: 使 用 mysqlL_num_rowsO 函 数 的 注意 事项 。 
mysql_ num rowsO 函 数 仅 对 select 查询 语句 有 效 。 


ee 
宗 
实例 368 趣味 指数 : 南座 评 商 ， 


力 实例 说 明 


如 果 想 要 查看 数据 表 中 某 个 单元 的 数据 ， 那 么 推荐 使 用 mysql_resultO 函 数 。 本 实例 将 介绍 如 何 使 用 
mysql_result0 函 数 获 取 结 果 集 中 指定 单元 的 数据 ， 运 行 结果 如 图 8.37 所 示 。 


££ 


横向 : 同 户 纵向 : 已 
职 得 字段 为 小 潘 
1 小 杨 1081 2010-07-14 
小 潮 1026 2010-07-14 
3 小 刘 1015 2010-07-14 
4 明日 mrsoft 2010-07-14 


图 8.37 取得 一 条 字段 


图 关键 技术 
mysql_result0 函 数 ， 用 于 返回 MySQL 结果 集中 一 个 单元 的 内 容 。 


mixed mysql_result ( resource result int row [. mixed field] ): 
参数 说 明 : 

resource result: 结果 集 。 

introw: 行 数 。 

mixed field: 可 选 参数 ， 字 段 名 称 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 命 名 为 让 php， 利 用 面向 对 象 知识 编写 数据 库 连接 类 。 
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(2) 创建 脚本 文件 ， 命 名 为 index.php。 首 先 ， 包 含 数据 库 连 接 类 ， 对 类 进行 实例 化 ， 连 接 数 据 库 。 然 后 ， 
通过 while 语句 和 mysql_fetch_ row0 函 数 循 环 输出 数据 表 中 数据 。 最 后 ， 根 据 form 表单 提交 的 数据 进行 判断 ， 
在 switch 语句 中 通过 mysql_result0 函 数 获取 数据 表 中 指定 单元 的 数据 ， 其 关键 代码 如 下 : 

<2php 


由 
这 $_ POST[sub]){ / 济 断 提交 按钮 的 值 是 否 为 真 

if($_POST[name] — 1||$_POST[name] < D{ 
echo "<script>alert( 选 择 的 是 表格 表 头 ");</script>"; 

jelsef 

switch($_POST[naD { /在 switch 语句 中 ， 根 据 表单 提交 的 值 进行 判断 
case "ID"; 
Srse = mysql_result($rs,$_POST[name]-1,"id"): // 获 取 指 定单 元 的 数据 
echo "取得 字段 为 "Srse; 
break; 
case "用 户 "; 
Srse = mysql_result($rs,$_POST[name]-1,"name"): 
echo "取得 字段 为 "Srse; 
break: 
case "密码 "; 
Srse = mysql result($rs,$ POST[namel-1,"pwd"): 
echo "取得 字段 为 ".Srse; 
break; 
case "日 期 "; 
Srse = mysql_result($rs,$_POST[name]-1,"date"); 


echo "取得 字段 为 ".$rse; 
break: 


?> 


图 秘笈 心 法 

心 法 领悟 368: 使 用 mysql_result0 函 数 的 注意 事项 。 

当 mysql resultO 函 数 作 用 于 很 大 的 结果 集 时 ， 应 该 考虑 使 用 能 够 取得 整 行 的 函数 。 这 些 函 数 在 一 次 函数 调 
用 中 返回 多 个 单元 的 内 容 ， 效 率 高 于 mysql_resultO 函 数 。 


实例 369 


趣味 指数 : 耸 容 窗帘 


力 实例 说 明 


MySQL 数据 库 的 主要 作用 在 于 能 够 存储 大 量 的 数据 ， 作 为 数据 的 规范 化 载体 ， 可 以 通过 Insert 添加 语句 将 
数据 添加 到 数据 表 中 。 本 实例 通过 INSERT 语句 向 图 书信 息 表 中 添加 信息 ， 运 行 结果 如 图 8.38 所 示 。 


» 


2 
插入 数据 
飞 二 :CHFR 晤 信和 和 
rs | 
CE xxxx-xz-rx 
司 
图 8.38 插入 数据 
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力 关键 技术 
insert 语句 向 数据 库 插入 一 条 数据 ， 语 法 如 下 : 


INSERT [LOW_PRIORITY | DELAYED | HIGH PRIORITY] [IGNORE] 
[INTO] tbl_name [(col name...)] 
VALUES (fexpr | DEFAULT},...).(..)... 
[ON DUPLICATE KEY UPDATE col name=expr, ...] 


本 实例 中 实现 添加 图 书信 息 的 SQL 语句 如 下 : 

$sql = "insert into tb_demo024(id,name.pwd.date)values(",'$_POST[n]','$_POST[na]''$_ POST[nam])": 
图 设计 过 程 

(1) 建立 nphp 文件 ， 编 写 MySQL 数据 库 的 连接 类 。 

(2) 编写 index.php 文件 ， 创 建 form 表单 ， 提 交 要 添加 的 图 书信 息 ， 将 数据 提交 到 本 页 。 获 取 表单 中 提交 
的 数据 ， 连 接 数 据 库 ， 通 过 insert 语句 将 表单 提交 的 数据 添加 到 指定 的 数据 表 中 ， 最 终 循环 输出 数据 表 中 的 数 
据 ， 其 关键 代码 如 下 : 


if($_POST[sub2){ 
if($_POST[n] 二 "1 $_POST[na] = ""||$_POST[nam] =""){ // 济 断 提交 的 数据 是 否 为 空 
iflpreg_match("/N\d/",$_POST[na]) { // 通 过 正 则 表达 式 判 断 提交 数据 格式 是 否 正确 
$sql = "insert into tb_demo024(id.name.pwd,date)values(",$_POST[n]''$_POST[na]'’$_POST[nam])"; 
这 mysql_query(SsqD){ /执行 添加 语句 
echo "<script>alert( 插 入 数据 成 功 ):location href="index.php?id=3';</script>"; 
} 
jelse{ 
echo "<script>alert( 您 输入 的 不 是 一 个 数字 人);</script>"; 
} 
jelsef 
echo "<scripf>alert( 文 本 框 为 空 );</script>" 
， 
秘笈 心 法 


心 法 领悟 369: 使 用 insert 语句 的 注意 事项 。 

在 PHP 中 ， 通 过 insert 语句 向 数据 表 中 添加 数据 时 ， 要 做 到 三 点 统一 : 

(1) form 表单 中 定义 的 表单 元 素 名 称 与 在 数据 处 理 页 中 通过 $_POST[] 方 法 获取 表单 元 素 值 使 用 的 名 称 统 

-， 同 时 还 要 注意 它们 是 区 分 字符 大 小 写 的 。 如 果 两 个 名 称 不 统一 ， 那 么 将 获取 不 到 指定 的 值 。 

(2) 在 编辑 的 insert 添加 语句 中 ,字段 的 名 称 与 字段 的 值 必须 对 应 ， 不 能 将 varchar 类 型 的 数据 添加 到 date 
类 型 的 字段 中 。 

(3) 在 编辑 的 insert 添加 语句 中 ， 字 段 的 名 称 必 须 与 数据 表 中 定义 的 字段 名 称 统一 ， 否 则 同样 会 导致 添加 
失败 。 


实 俩 
实例 370 趣味 指数 : 斌 裔 请 请 
力 实例 说 明 

数据 库 可 以 与 PHP 页 面 进行 很 好 的 交互 ， 既 可 以 向 数据 库 中 插入 数据 ， 也 同样 可 以 从 数据 库 中 查询 数据 。 
本 实例 通过 SELECT 语句 实现 查询 图 书信 息 ， 运 行 结果 如 图 8.39 所 示 。 
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一 一 而 因 书 信和 

1 《PRP 开 发 实 瑟 字 现 》 [5 元 105-07-15 
日 《PhP 内 络 编 各 自 全 手 新 》 下 3 [a3 39-07-15 
3 | 《PRP 球 浴 叔 程 》 | 天 |291 9-07-17 
| rr [元 | 


图 8.39 查询 图 书信 息 


国 关键 技术 


SELECT 语句 是 在 SQL 中 比较 常用 的 语句 ， 也 是 比较 重要 的 语句 。 使 用 SELECT 语句 可 以 从 数据 表 或 视图 
中 进行 查询 ， 并 将 查询 结果 以 表格 的 形式 返回 ， 以 表格 返回 的 结果 也 可 以 称 为 结果 集 。SELECT 语句 中 的 主要 
结构 如 下 : 


SELECT select list 

[INTO new table namel 

FROM table_list 

[WHERE search_conditions] 
[GROUP BY group by list] 

[ HAVING search_conditions] 
[ORDER BY order list [ASC| DESC ]] 


参数 说 明 : 

select_list: 指定 需要 查询 返回 的 列 。 多 个 列表 之 间 使 用 逗号 分 隔 。 在 选择 列表 时 也 可 以 使 用 “*” 符 号 来 表 
示 返 回 表 中 的 所 有 列 。 

INTO new _table_ name: 创建 新 表 并 将 查询 行 插入 新 表 中 。new_table name 指定 新 表 的 名 称 。 

FROM table list， 指定 需要 查询 的 表 。 这 些 来 源 表 可 能 包括 基 表 、 视 图 和 链接 表 。FROM 子 句 还 可 包含 连 
接 说 明 ， 该 说 明定 义 了 SQL Server 用 来 在 表 之 间 进 行 导航 的 特定 路 径 。 

WHERE search_conditions: WHERE 子 句 指定 用 于 限制 返回 的 行 的 搜索 条 件 。 

GROUP BY group_by_list: GROUP BY 子 句 根据 group_by_list 列 中 的 值 将 结果 集 分 成 组 ,例如 , student 表 
在 “性别” 中 有 两 个 值 。GROUP BY ShipVia 子 句 将 结果 集 分 成 两 组 ， 每 组 对 应 于 ShipVia 的 一 个 值 。 

HAVING search_conditions: HAVING 子 句 指定 组 或 聚合 的 搜索 条 件 。 逻 辑 上 讲 ，HAVING 子 句 从 中 间 结 
果 集 对 行进 行 筛选 ， 这 些 中 间 结 果 集 是 用 SELECT 语句 中 的 FROM、WHERE 或 GROUP BY 子 句 创建 的 。 
HAVING 子 句 通常 与 GROUP BY 子 句 一 起 使 用 ， 尽 管 HAVING 子 句 前 面 不 必 有 GROUP BY 子 句 。 

ORDER BY order list[ ASC | DESC ]: ORDER BY 子 句 定义 结果 集中 的 行 排列 的 顺序 。order list 指定 组 成 
排序 列表 的 结果 集 的 列 , ASC 和 DESC 关键 字 用 于 指定 行 是 按 升 序 还 是 按 降序 排序 .ORDER BY 之 所 以 重要 ， 
是 因为 其 关系 理论 规定 除非 已 经 指定 ORDER BY, 否则 不 能 假设 结果 集中 的 行 带 有 任何 序列 。 如 果 结 果 集 中 行 
的 顺序 对 于 SELECT 语句 来 说 很 重要 ， 那 么 在 该 语句 中 就 必须 使 用 ORDER BY 子 句 。 
图 设计 过 程 

(1) 建立 in.php 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 

(2) 编写 index.php 文件 , 包含 数据 库 连 接 类 , 实例 化 对 象 ， 连接 数据 库 。 然后, 执行 查询 语句 , 通过 while 
语句 和 mysql fetch_row0 函 数 循 环 输出 查询 结果 ， 核 心 代码 如 下 : 

<?php 


include("in.php"); // 包 含 数据 库 连 接 类 
new mysql("localhost","root"."111","db_database08"); 1/ 实例 化 对 象 
if($_GET[id] — D{ /1/ 如 果 地 址 栏 参 数 id 等 于 1 
Srs = mysql_query("select * from tb_demo025"); // 返 回 结果 集 
echo "<table width 一 580px>": /输出 结果 


echo "<tr><td style='color-#FFFFFF>ID</td><td bgcolor=#FFFFFF> 书 名 </td><td style='color#FFFFFF> 价 格 </td><td 
bgcolor=#FFFFF> 日 期 <td></tr>"; 
while($rst = mysql fetch row(Srs)){ 
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echo "<tr><td >".$rst[0]."</td><td bgcolor=#FFFFFF'>".$rst[1]."</td><td >".$rst[2]."</td><td>".$rst[3]."</td></tr>"; 
} 
echo "</table>"; 
2 


> 


图 秘笈 心 法 

心 法 领悟 370: SELECT 语句 的 优点 。 

灵活 运用 SELECT 语句 ， 可 以 编写 出 非常 复杂 的 查询 ， 如 单列 查询 、 多 列 查询 、 查 询 所 有 列 、 别 名 的 应 用 、 
TOP 查询 前 若干 行 、 计 算 列 查询 、 条 件 查询 和 范围 查询 等 。 


图 实例 说 明 


select 语句 可 以 查询 数据 库 信 息 ， 但 是 如 果 数 据 库 信 息 非常 多 ,在 一 个 页 面 中 显示 所 有 数据 ， 首 先 会 使 页 面 
显得 繁杂 、 不 美观 ， 其 次 会 给 用 户 造 成 网 站 不 够 智能 的 表象 。 本 实例 灵活 运用 SELECT 语句 实现 对 图 书信 息 的 
分 页 处 理 ， 其 运行 结果 如 图 8.40 所 示 。 


杰 消 国 书 情思 

首页 上 一 页 下 一 克 加 页 

但 书 名 价格 习 其 

4 《C1 开发 实 成 室 央 》 1 大 2010-07-16 
上 《Fe 开导 实 碾 到 大 EE EI 
日 《PRE 药 全 京 关 ) it M007-16 
s 《7 元 例 室 商 》 EE D7 
1 《TAN4 范 合 宣 下 》 1 元 007-16 


图 8.40 分 页 显示 图 书信 息 


图 关键 技术 


本 实例 应 用 select 查询 语句 及 其 子 句 limit， 实 现 图 书信 息 的 分 页 显示 。 通 过 limit 关键 字 控 制 当 前 页 面 显示 


的 记录 数 和 开始 位 置 。 本 实例 分 页 查询 图 书信 息 的 SQL 语句 代码 如 下 : 
$sql = "select * from tb_demo026 limit ".(($page - 1)*$num).",". Snum; 


其 中 (($page - 1)*$num) 计 算 的 是 当前 页 的 开始 位 置 ， 而 $num 是 当前 页 显示 的 记录 数 。 
图 设计 过 程 

(1) 建立 nphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 

(2) 编写 index.php 文件 。 首 先 ， 包 含 数据 库 连 接 类 并 实例 化 对 象 。 然 后 ， 定 义 查 询 语句 统计 查询 结果 集 
bh 的 记录 数 ， 定 义 分 页 变量 。 接 着 ， 定 义 分 页 查询 语句 ， 每 页 显示 5 条 记录 。 最 后 ， 创 建 分 页 超 链接 ， 完 成 图 
书信 息 的 分 页 显示 ， 核 心 代码 如 下 : 


<2php 
include("in.php"): // 包 含 数据 库 连 接 类 
new mysql("localhost","root"."111","db_database08"); /实例 化 对 象 
if($_GET[id] — D{ 1/ 如果 地 址 栏 参数 等 于 1 
Snum= 5; // 定 义 变 量 
Srse = mysql_query("select * from tb_demo026"): /执行 查询 操作 
Snu = mysql_num rows(S$rse); /上 返回 数据 库 信息 条 数 
if(!$_GET[pageD{ // 设 置地 址 栏 参数 page 
Spage=1; 
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Jelse{ 
Spage =$_GET[page]; 
上 
$sql = "select * from tb_demo026 limit ".(($page - D)*Snum)."".Snumz:// 分 页 sql 语句 
Srs= mysql_query($sqD); /返回 结果 集 
Snur = ceil(Snu/Snum): / 取 整 函数 
echo "<a href='index.php?id=1&page=1> 首 页 </a>"; // 设 置 主页 地 址 栏 参 数 
if($page > 一 2){ /如 果 地 址 栏 参数 page 值 大 于 等 于 2 
> 
<a href="index.php?id=1&:page=<?php echo $page-1:?>"> 上 一 页 </a> 。 /一 页 
php , 
这 Spage< Snun){ /如 果 page 小 于 总 页 数 
<a href="index.php?id=1&page=<?php echo $paget+1:?>"> 下 一 页 </a> /下 一 页 
<?php 
> 
<a href="index.php?id=1&page=<?php echo Snur:?>"> 尾 页 </a> // 尾 页 
<?php 


echo "<table width='580px'><tr><td width="100px’ bgcolor=#FFFFFF>ID</td><td width 一 200px'> 书 名 </td><td width 一 180px' 
bgcolor=#FFFFFF> 价 格 </td><td width="100px> 日 期 <ltd></tr>"; 
while($rst = mysql_fetch_row($rs){ 
echo "<tr><td bgcolor=#FFFFFF>".$rst[0]."</td><td> (".$rst[1].") </td><td bgcolor=#FFFFFF'>".$rst[2]."</td><td>".Srst[3]."</td></tr>"; 
} 
echo "</table>"; 
上’. 
> 


力 秘笈 心 法 

心 法 领悟 371: SELECT 语句 的 子 句 limit。 

Select 语句 的 子 句 limit 功能 很 强大 ， 可 用 于 控制 查询 语句 的 开始 位 置 以 及 查询 的 数量 。 但 是 ，limit 子 句 是 
MySQL 数据 库 特 有 的 ， 在 SQL Server 或 者 Access 数据 库 中 是 不 支持 的 。 


实例 372 


力 实例 说 明 


程序 员 在 手动 插入 大 量 数据 的 时 候 ， 难 免 将 图 书信 息 的 某 个 字段 书写 错误 ， 这 个 时 候 就 需要 使 用 update 语 
名 更 新 信息 。 本 实例 通过 update 语句 实现 更 新 图 书信 息 ， 运 行 结果 如 图 8.41 所 示 。 


nm 日 其 排 作 
1 Zn 更 新 
= FI EL 
3 I 更 
4 ai 更新 
To= [EE 祁 | 


图 8.41 更 新 图 书信 息 


图 关键 技术 


update 语句 用 于 修改 表 中 的 数据 ， 通 常 有 两 种 形式 ， 一 是 可 以 一 次 向 表 中 修改 多 条 数据 (实现 一 改 全 改 ); 
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二 是 只 修改 一 条 记录 ， 其 语法 格式 如 下 : 


UPDATE{ 
table_name WITH ( <table_hint limited >[..n]) 
| view name 
| rowset_function limited 
} 


SET 
{ column name = { expression | DEFAULT | NULL } 
| @variable = expression 


| @variable = column = expression } [ni1 
{ {[FROM { <table source>}[,..n]] 


< search condition >1} 
| 
[WHERE CURRENT OF 
{ {[ GLOBAL ] cursor name } | cursor variable name } 


]} 
[ OPTION (< query hint>[,.n])] 
<table source > := 
table_name [[ As ] table alias ] [ WITH ( <table hint>[,..n])] 
|view_name [[ AS ] table alias] 
|rowset function [ [AS] table alias] 
| derived_table [AS] table_alias [ (column alias[,.n])] 
|<joined table> 
<joined table>::= 
< table_source > < join type > <table_source > ON < search_condition > 
|<table_source > CROSS JOIN < table_source > 
|<ioined table> 


<join type> := 
[INNER | { { LEFT | RIGHT | FULL } [OUTER] }] 
[<join hint >] 
JOIN 

<table_hint limited > ;:= 
{ FASTFIRSTROW 


{ INDEX(index val[..n]) 
|FASTFIRSTROW 
HOLDLOCK 


TABLOCKX 
|UPDLOCK 


< query_hint > :一 
{ {HASH|ORDER}GROUP 
{ CONCAT | HASH | MERGE } UNION 
{LOOP | MERGE | HASH } JOIN 
|FAST number rows 
FORCE ORDER 
MAXDOP 
|ROBUST PLAN 
KEEP PLAN 
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了 
参数 说 明 : 
table_name: 要 更 新 的 表 的 名 称 。 如 果 该 表 不 在 当前 服务 器 或 数据 库 中 ,或 不 为 当前 用 户 所 有 ， 此 名 称 可 用 

连接 服务 器 、 数 据 库 和 所 有 者 名 称 来 限定 。 

WITHC<table hint limited>[...n]): 指定 目标 表 所 允许 的 一 个 或 多 个 表 提 示 。 需要 有 WITH 关键 字 和 圆 括号 
不 允许 有 READPAST、NOLOCK 和 READUNCOMMITTED。 

view_name: 要 更 新 的 视图 的 名 称 。 通 过 view_name 来 引用 的 视图 必须 是 可 更 新 的 。 用 update 语句 进行 的 
修改 ， 至 多 只 能 影响 视图 的 FROM 子 句 所 引用 的 基 表 中 的 一 个 。 

rowset_function_limited: OPENQUERY 或 OPENROWSET 函数 ， 视 提供 程序 功能 而 定 。 

SET: 指定 要 更 新 的 列 或 变量 名 称 的 列表 。 

column name: 含有 要 更 改 数 据 的 列 的 名 称 。column_name 必须 驻 留 于 update 子 句 所 指定 的 表 或 视图 中 ， 
标识 列 不 能 进行 更 新 。 

图 设计 过 程 
(1) 建立 inphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 

(2) 编写 index.php 文件 。 首 先 ， 包 含 数 据 库 连接 文件 ， 执 行 类 的 实例 化 并 连接 数据 库 。 然 后 ， 循 环 输出 
数据 表 中 数据 ， 并 且 为 每 条 记录 创建 一 个 “更 新 ” 超 链接 ， 链 接 到 当前 页 ， 传 递 参 数 为 该 条 记录 的 ID 值 。 最 后 ， 
根据 超 链接 传递 的 参数 值 进行 判断 ， 如 果 符 合 要 求 则 输出 form 表单 ， 将 更 新 数据 提交 到 本 页 ， 完 成 数据 的 更 新 
操作 ， 核 心 代码 如 下 : 


new mysql("localhost", "root","111","db_database08"): // 连 接 数 据 库 
if($ POST[sub1D){ 
这 $_POST[na] 一 "更 新 书 名 " || $_POST[nam] 一 "更 新 价格 "||$_POST[name] 一 "更 新 日 期 "){ 
echo "<scriptf>alert( 有 文本 框 未 做 更 新 ， 请 重新 填写 ):location href='index.php?id=1'</script>"; 
jelsef 
$sql = "update tb demo027 set bname='$ POST[nal',price-S POSTfnam],date-S POST[namel where id-S GET[updatel"; 
这 mysql_query($sqD){ 
echo "<script>alert( 更 新 成 功 ");</script>"; 
1 


} 
> 


秘笈 心 法 

心 法 领悟 372: 使 用 update 语句 的 注意 事项 。 

在 使 用 update 更 新 语句 时 ， 要 注意 where 子 句 的 使 用 ， 如 果 不 存在 where 子 句 ， 则 会 更 新 数据 库 中 的 所 有 
数据 。 所 以 ， 在 应 用 update 语句 执行 更 新 操作 时 ， 必 须 指定 更 新 的 条 件 ， 而 这 个 条 件 最 理想 的 选择 就 是 数据 的 
ID， 即 数据 表 中 字段 的 主键 。 


高 级 
趣味 指数 ， 依 寅 请 请 : 


力 实例 说 明 


对 于 数据 类 型 相同 的 数据 信息 ， 用 户 没有 必要 对 数据 进行 逐条 更 新 ， 可 以 通过 批量 更 新 一 次 解决 。 本 实例 
通过 Update 更 新 语句 实现 图 书信 息 的 批量 更 新 ， 运 行 结果 如 图 8.42 所 示 。 
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和 大“@ 节 信息 的 小 吾 更 新 


字段 硕 人 首 地 让 名 称 更 新 。 更 新 内 雁 从 TD。 各 寺 号 中 到 TD。 尾 施 号 中 


1_ |pRP 开 发 实战 宝 开 80 元 2010-07-17 
2 |V8 开 发 实 戌 宝 实 B80 元 2010-07-17 
3 |IAWA 开 发 实战 宝 南 9 元 2010-07-17 
JAYAWEB 开 发 实战 字 册 [本 2010-07-17 
5 | NET 开 发 实战 宝 实 78 元 2010-07-17 
6 jc 开发 实战 宝典 78 元 2010-07-17 


8.42 ”批量 更 新 


图 关键 技术 


本 实例 实现 批量 更 新 图 书信 息 的 SQL 语句 的 代码 如 下 : 

Update tb_demo028 set date='$_POST[name]'where (id>=$_POST[na] and id<=$_POST[nam]): 

本 实例 的 匹配 更 新 是 通过 where 子 句 的 执行 条 件 来 完成 的 ， 更 新 的 是 date 字段 的 值 ， 其 更 新 的 范围 是 id 大 
于 $_POST[nal]、 小 于 等 于 $_ POST[nam] 的 数据 。 


图 设计 过 程 

(1) 建立 mphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 

(2) 编写 index.php 文件 。 首 先 ， 创 建 form 表单 ， 将 更 新 数据 提交 到 本 页 。 然 后 ， 包 含 数据 库 连 接 类 并 实 
例 化 对 象 。 接 着 ,判断 表单 中 提交 的 数据 ， 根 据 判 断 结 果 执行 不 同 的 更 新 语句 。 最 后 ， 循 环 输出 数据 表 中 数据 ， 
核心 代码 如 下 : 


<?php 
include("in.php"); 
new mysql("localhost","root","111","db_database08"); /连接 数据 库 
if($_POST[sub){ 
if($ dd el |$_POST[name] 一 "更 新 内 容 "||$ POST[na] 一 " 首 字母 ID" | $_POST[nam] 一 " 尾 字母 ID"){ 
echo "<script>alert( 请 将 文本 框 内 容 填 写 完整 );</script>"; 


} 
过 ee 四 ="ID"||$_POST[n] = "id"||$_POST[n] = "Id" ||$_POST[n] = "iD"){ 
echo "<script>alert(ID 主键 无 法 更 新 ):</script>"; 


is POSTm] 一 " 书 名 "){ 
站 demo028 set bname=-'$_POST[name]'where (id>=$ 1 a POST[nam])")){ 
echo "<script>alert( 批 量 更 新 书 名 完成 ):location href-index.php'</script>": 
jelsef 


echo "<script>alert( 输 入 信息 有 误 );</script>"; 
} 


} 
/省 略 了 部 分 代码 
} 
S$rs = mysql query("select * from tb demo028"): 
?> 


力 秘笈 心 法 
心 法 领悟 373: update 批量 更 新 。 
在 本 实例 中 ， 通 过 批量 更 新 将 指定 字段 的 值 统一 更 新 为 一 个 新 的 值 。 还 可 以 通过 批量 更 新 将 指定 字段 更 新 


为 不 同 的 值 ， 完 成 这 个 操作 首先 需要 form 表单 提交 多 个 不 同 的 值 ， 然 后 通过 while 循环 读 取 提交 的 值 ， 并 且 循 
环 执行 更 新 语句 ， 即 可 实现 。 
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趣味 指数 : 便便 凋 衣 


图 实例 说 明 


数据 库 可 以 长 期 储存 数据 ， 但 是 如 果 不 能 及 时 删除 一 些 已 经 过 期 不 再 使 用 的 数据 或 者 元 余数 据 信息 ， 会 影 
响 到 MySQL 服务 器 的 执行 效率 , 所 以 删除 不 再 使 用 的 数据 是 十 分 必要 的 。 本 实例 通过 delete 语句 实现 删除 图 书 
信息 ， 运 行 结果 如 图 8.43 所 示 。 


全 
删除 @ 书 信息 
spo I 
10 书包 价格 日 其 
1 PhP 开 复 实 岂 宝 实 8 元。 20F07-17 
Wi 开发 实 B2017 


JAW4 开 发 实战 宝 湛 7 沅 anE0-17 
JAVAWEB 开 发 实 研 宝 页 8 无 20F0-17 


图 8.43 ”删除 图 书信 息 


图 关键 技术 

Delete 语句 用 于 删除 表 中 的 数据 ， 通 常 有 两 种 形式 ， 一 是 可 以 一 次 删除 表 中 多 条 数据 ， 二 是 一 次 只 删除 一 
条 记录 ， 其 语法 格式 如 下 : 

DELETE [FROMI 

{table_name | view_name} 

[WHERE search_conditions] 

参数 说 明 : 

table_name: 指定 要 删除 数据 的 数据 表 的 名 称 。 

view_name: 用 于 要 删除 数据 的 视图 。 

search_conditions: 使 用 搜索 条 件 来 限定 要 删除 的 数据 行 。 
图 设计 过 程 

(1) 建立 in.php 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 

(2) 编写 index.php 文件 。 首 先 ， 创 建 form 表单 ， 将 删除 数据 的 ID 提交 到 本 页 。 然 后 ， 包 含 数据 库 连 接 
类 并 实例 化 对 象 ， 判 断 表单 中 提交 的 数据 是 否 符合 要 求 ， 如 果 符合 要 求 ， 则 执行 delete 删除 语句 。 最 后 ， 循 环 
输出 数据 表 中 数据 ， 核 心 代码 如 下 : 

<?php 


include("“in.php"); // 包 含 数 据 库 连 接 类 
new mysql("localhost", "root","111","db_database08"):; /实例 化 对 象 
if($_POST[sub){ / 单 击 删 除 按钮 
iflpreg_match("N\d/",$_POST[naD)){ // 首 先 验证 文本 框 是 否 为 数字 
if(mysql_query("delete from tb_demo029 where id='$_POST[na]"){ /执行 删除 操作 
echo "<script>alert( 删 除 成 功 ):</script> /输出 提示 
jelsef 
echo "<script>alert( 您 输入 的 商品 ID 不 在 范围 内 ):</scripf>": 
} 
jelsef 
echo "<script>alert( 您 输入 的 图 书 ID 不 是 数字 ?):</script>": 
} 
由 
Srs = mysql_query("select * from tb_demo029"); /查询 操作 输出 信息 
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echo "<table width='580px'><td>ID</td><td> 书 名 </td><td> 价 格 <td><td> 日 期 <ltd></tr>"; 
while($rst = mysql fetch row($rs)){ 
echo "<td>".$rst[01."</td><td bgcolor=#FFFFFF>".$rst[11."</td><td>".$rst[21."</td><td bgcolor=#FFFFFF>".$rst[31."</td></tr>"; 


: 
ho "</table>"; 


图 秘笈 心 法 
心 法 领悟 374: 使 用 delete 语句 的 注意 事项 。 
如 果 用 户 编写 的 delete 语句 中 没有 where 子 句 ， 则 所 有 的 字段 信息 都 将 被 删除 。 


趣味 指数 : 侠 穴 容 寅 


实例 375 


力 实例 说 明 


假设 在 数据 表 中 有 多 条 错误 信息 或 者 了 见 余数 据 需要 用 户 手 动 删除 ， 如 果 用 户 逐 一 删除 ， 未 免 浪 费时 间 ， 降 
低 用 户 的 工作 效率 。 本 实例 推荐 一 种 高 效 的 删除 方法 ， 实 现 数据 的 批量 删除 。 运 行 本 实例 ， 如 图 8.44 所 示 ， 对 
网 络 聊天 室 中 的 数据 进行 管理 ， 选 中 一 条 或 者 多 条 数据 ， 单 击 “ 删 除 ”按钮 即 可 实现 将 选中 的 所 有 数据 删除 。 


A 区 OCR 


EE RS | 遇 PP | 
EE 


F | 得 | 天 | 下 晤 于 om-oets |ie. ie.1.59 | 


LN em 


图 8.44 批量 删除 数据 


图 关键 技术 
批量 删除 数据 同样 应 用 的 是 delete 语句 , 只 是 在 处 理 提交 的 数据 时 应 用 while 循环 语句 、 list0 和 each0 函 数 。 
list0 函 数 的 语法 如 下 : 


void list(...); 

该 函数 用 于 一 次 性 为 多 个 变量 赋值 。 

each0) 函 数 的 语法 如 下 : 

array each( array array): 

该 函数 用 于 依次 返回 参数 array 所 指定 的 数组 的 元 素 下 标 和 该 下 标 所 对 应 的 数组 元 素 值 , 并 且 每 获取 一 个 数 
组 元 素 后 ， 自 动 使 数组 指针 向 下 移 一 位 。 该 函数 将 返回 一 个 数组 ， 该 数组 的 下 标 只 有 0、key、1 和 value 这 4 
个 数值 ， 其 中 下 标 为 0 和 key 的 数组 元 素 值 相等 ， 表 示 该 函数 的 参数 所 指定 数组 的 当前 元 素 的 下 标 ， 而 下 标 为 
1 和 value 的 数组 元 素 值 相等 ， 表 示 该 参数 所 指定 数组 的 当前 元 素 值 。 

while 循环 语句 是 PHP 语言 站 用 的 位 不 语 人 和 的 一 Ls 该 语句 的 基本 格式 如 下 : 


i /用 着 入 法 的 村 式 
while 循环 是 PHP 最 简单 的 循环 语句 。 只 要 while 表达 式 的 值 为 TRUE 就 重复 执行 该 表达 式 中 的 语句 体 , 如 
果 while 表达 式 的 值 一 开始 就 是 FALSE， 则 循环 语句 体 一 次 也 不 执行 。 
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图 设计 过 程 
(1) 新 建 conn.php， 创 建 与 数据 库 的 连接 ， 其 代码 如 下 : 
<?php 


$conn=mysql_connect("localhost","root","111")or dir( 服 务 器 连接 失败 :. mysql_error0); 
mysql_select_db(rdb_database08".Sconn): 
民生。 query("set names utf8"): 


“2) 创建 显示 数据 库 中 数据 的 表格 , 读 取 数据 库 中 的 数据 , 设置 批量 删除 数据 的 提交 按钮 ， 关键 代码 如 下 : 
<?php session start(); include("conn/conn.php"); 
<form name="forml" method="post" action="index_ok.php"> 
<table width="486" border="1" cellpadding="0" cellspacing="0"> 
<?php $query=mysql_query("select * from tb_chartroom"); 
if($query—trmue){ 
while(S$myrow=mysql fetch array(Squery)){ 


<u> 

<td align="center"><span class="STYLE2"> 
<input type="checkbox" name="<?php echo Smyrow[lid];?>" value="<?php echo Smyrowlid];?>"> 

</span></td> 
<td height="25" align="center"><span class="STYLE2"><?php echo $myrow[fusemamel;?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrow[to_usermmame]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrow[text];?></span></td> 
<td align="center"><span class="STYLE2"><?php echo Smyrow[data]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrow[ip];?></span></td> 

</t> 

<?php )) ?> 
<t> 


<td height="25" colspan="4" align="center">énbsp:</td> 
<td colspan="2" align="left"><input type="submit" name="Submit" value=" 删 除 "></td> 
</t> 
</table> 
</form> 
(3) 对 表单 提交 的 数据 进行 处 理 ， 完 整 的 代码 如 下 : 
<?php session start(); include("conn/conn.php"): 
iiSSubmit 一 "删除 ")f 
while(list($name, $value)=each($_POST){ 
Sresult=mysql_query("delete from tb_chartroom Where id=".$name.™"); 
这 Sresult 一 true){ 
echo "<script>alert( 删 除 成 功 !"); window location href-'index .php':</script>": 
Jelse{ 
echo "<script>alert( 失 败 !); window.location href='index.php':</script>":} 
由 
> 


力 秘笈 心 法 


心 法 领悟 375: 制作 批量 删除 程序 的 注意 事项 。 
在 制作 批量 删除 程序 时 ， 最 好 建立 提示 页 面 确认 是 否 删除 ， 否 则 如 果 由 于 意外 删除 数据 ， 会 给 用 户 带 来 不 
必要 的 损失 。 


人 


图 实例 说 明 


将 数据 库 中 信息 显示 到 网 页 中 经 常会 遇 到 这 样 的 问题 ， 即 网 页 中 输出 的 中 文 文字 为 乱码 。 造 成 该 问题 的 主 
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要 原因 是 数据 库 中 的 编码 格式 与 页 面 设置 的 编码 格式 不 符 或 者 没有 将 数据 信息 统一 为 GBK、GB2312 或 utf-8。 
本 实例 通过 设置 编码 格式 演示 如 何 避 免 输出 中 文字 符 串 时 出 现 乱 码 ， 运 行 结果 如 图 8.45 所 示 。 


于 


rset EB 


TD 韦 名 
PRP1TT7D 3T 
ML 


日 期 

200-17 
2 E07 
Ela 
ZN E07 
ZN F077 
ZN E07 
2 F017 


EDD 


图 8.45 错误 设置 编码 格式 输出 中 文 


图 关键 技术 


set 语句 用 于 设置 不 同 变量 ， 其 语法 如 下 : 
SET variable assignment [, variable assignment] ... 
variable_assignment: 
user Var name = expr 
| [GLOBAL | SESSION] system var_name = expr 
|@@[global. | session.]system var name = expr 
本 实例 通过 set 语句 设置 页 面 的 编码 格式 ， 其 代码 如 下 : 


set names $_ POST[name]; 
图 设计 过 程 

编写 脚本 文件 ， 命 名 为 index.php。 创 建 form 表单 ， 将 要 设置 的 编码 格式 提交 到 本 页 。 在 本 页 中 连接 服务 
器 和 指定 的 数据 库 ， 根 据 form 表单 提交 的 数据 设置 数据 库 的 编码 格式 ， 然 后 循环 输出 数据 库 中 的 数据 ， 其 代码 


如 下 : 
<?php 
ifS_POST[sub])f // 单 击 “ 确 定 ” 按 钮 
这 $_POST[name] 一 "|| $_POST[name] 一 "输入 编码 格式 "){ /如 果 文 本 框 为 空 或 初始 值 
echo "<script>alert( 文 本 框 内 容 不 正确 ;</script>"; 
jelsef 
$conn = mysql_connect("localhost","root"."111") or dir ("connect MySQL false"): /连接 MySQL 数据 库 
mysql_select_db("db_database08".$conn) or die ("connect database false"): // 连 接 数据 库 
mysql_query("set names $_ POST[name]"): // 设 置 编码 格式 
Srs = mysql_query("select * from tb_demo031"): /1/ 返 回 结果 集 
echo "<table width='580px'><tr><td bgcolor=#FF0000>ID</td><td bgcolor=#FF0000> 书 名 </td><td bgcolor=#F0000> 价 格 </td><td 
bgcolor=#FF0000> 日 期 </td></tr>": 
while(Srst = mysql_fetch row(Srs)){ /循环 输出 


echo "<tr><td bgcolor-#FF0000>" .Srst[0]."</td><td bgcolor=#FF0000>".$rst[1]."</td><td bgcolor-#FF0000>".Srst[2]. 
“</td><td bgcolor=#FF0000>".Srst[31."</td></tr>"; 
i 
echo "</table>"; 


} 
> 


力 秘笈 心 法 


心 法 领悟 376: SET 关键 字 的 特点 。 
set 语句 用 于 设置 不 同类 型 的 变量 ， 这 些 变量 会 影响 服务 器 或 客户 端的 操作 。SET 关键 字 可 以 用 于 向 用 户 变 
量 或 系统 变量 赋值 。 


513 


PHP 开发 实战 1200 例 (第 I 卷 ) 
高 级 
趣味 指数 :请 请 南 育 


图 实例 说 明 


创建 数据 库 的 方法 有 很 多 ， 例 如 在 cmd 命令 提示 符 下 通过 CREATE 语句 创建 MySQL 数据 库 ， 或 通过 
phpMyAdmin 等 图 形 化 管理 工具 创建 数据 库 。 本 实例 通过 表单 提交 和 函数 实现 动态 创建 MySQL 数据 库 ， 运 行 
结果 如 图 8.46 所 示 。 


动 六 创建 MYSQL 数据 计 
eT 四 动态 创建 数据 库 


图 8.46 动态 创建 数据 库 


图 关键 技术 


本 实例 主要 应 用 的 是 SQL 语句 中 的 create database 语句 ，create database 语句 的 格式 如 下 : 


create database db_name ; 
其 中 ，db_name 是 要 创建 的 数据 库 名 称 ， 该 名 称 必须 是 合法 的 ， 不 能 够 与 其 他 数据 库 重 名 。 
本 实例 实现 创建 数据 库 的 SQL 语句 的 代码 如 下 : 
create database $_POST[name]; 
力 设计 过 程 
编写 index.php 文件 ， 引 入 CSS 样式 表 ， 编 写 网 页 页 面 结构 并 包含 图 片 。 当 单 击 “ 创 建 ”按钮 时 ， 首 先 对 


文本 框 进行 数据 验证 ， 然 后 连接 MySQL 数据 库 ， 通 过 mysql_query0 函 数 实现 动态 创建 MySQL 数据 库 ， 代 码 
如 下 : 


<Iphp 
if($_GET[id] 一 '1){ / 单 击 按钮 
echo "<form action=" method='post>"; / 匾 写 fomm 表单 
echo "<input class='one'type='text size="10' name= name' value= 数据 库 名 称 >": 
echo "&nbsp;&nbsp:&nbsp:<input class='two' type='submit name='sub' Value='&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:": 


echo "</form>"; 
这 $_POST[sub]){ / 单 击 “ 创 建 ”按钮 
这 $_POST[name] 一 "||$_POST[name] 一 "数据库 名 称 "){ /验证 文本 框 是 否 为 初始 值 或 空 值 
echo "<script>alert( 请 填写 正确 数据 库 名 称 ):</script>": 
Jelse{f 
if(preg_match("/\w/".$_POST[name]){ // 正 则 表达 式 限制 文本 框 输入 内 容 
Sconn = mysql_connect("localhost","root”","111"); // 连 接 MySQL 数据 库 
这 mysql query("create database $_POST[name]"){ /如果 创建 成 功 
echo "<script>alert( 创 建 数据 库 成 功 ):</script>"; /输出 提示 
} 
jelsef 
echo "<script>alert( 请 不 要 使 用 特殊 字符 或 中 文字 符 "):</script>"; 
} 
上’; 
2 
图 秘笈 心 法 


心 法 领悟 377: 对 于 合法 的 数据 库 〈 包 括 MySQL 其 他 操作 对 象 ) 的 命名 有 如 下 一 些 规则 ; 
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(1) 名 称 可 以 由 任意 字母 、 数 字 、“ 一 ”或 者 “$” 组 成 ， 可 以 使 用 上 述 的 任意 字符 开头 ， 但 不 能 使 用 单 


独 的 数字 ， 那 样 会 造成 其 与 数值 的 混淆 。 
(2) 名 称 长 度 的 限制 为 : 数据 库 、 表 、 列 和 索引 的 名 称 最 多 由 64 个 字符 组 成 ， 而 别名 最 长 可 达 256 个 字符 。 
(3) 不 能 使 用 MySQL 的 关键 字 作为 数据 库 名 和 表 名 。 


力 实例 说 明 


单纯 地 创建 数据 库 毫 无 意义 , 因为 所 有 的 数据 都 是 以 数据 表 的 形式 存储 在 数据 库 中 。 本 实例 通过 create table 
语句 实现 动态 创建 数据 表 ， 运 行 结果 如 图 8.47 所 示 。 


动 访 人 建交 据 顽 | 


动态 创 填 数据 素 


ee [vs 品 | 


图 8.47 动态 创建 数据 表 


图 关键 技术 


本 实例 主要 应 用 SQL 语句 中 的 create table 语句 来 动态 创建 数据 表 。create table 语句 的 语法 如 下 : 
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] table name 


[(create_definition,. ..)][table_options] [select_statement] 

本 实例 实现 动态 创建 数据 表 的 SQL 语句 的 代码 如 下 : 

create table $ POST[n](id int(4) auto_increment primary key): 
图 设计 过 程 

创建 index.php 文件 ， 首 先 通 过 下 拉 列 表 框 循环 输出 数据 库 中 存储 的 数据 ， 然 后 ， 选 择 指定 的 数据 库 ， 单 击 
“确定 ”按钮 ， 在 弹出 的 文本 框 中 添加 数据 表 名 称 ， 并 且 指 定编 码 格式 ， 单 击 “确定 ”按钮 ， 提 交 创 建 数据 表 
的 数据 。 最 后 ， 获 取 form 表单 提交 的 数据 ， 完 成 数据 表 的 创建 操作 ， 其 关键 代码 如 下 : 


<?php 
if($_POST[sub1){ / 单 击 “ 确 定 ” 按 钮 
if($ ] Fos = 二 "||$_POST[n] 一 "数据 表 名 称 "){ /有 验证 文本 框 是 否 为 空 或 初始 值 
echo "<script>alert( 请 填写 正确 的 数据 表 名 称 ):</script>"; /输出 提示 
jelsef 
这 preg_match(www/".S_POST[nD){ // 过 滤 中 文字 符 和 特殊 字符 
if($_POST[select1] = "111"){ // 如 果 下 拉 列 表 框 值 不 为 111 
// 连 接 MySQL 数据 库 
S$conn = mysql_connect("localhost"."root"."111") or die ("connect mysql false"): 
/连接 数据 库 
mysql select db("$ SESSIONTid]".Sconn) or die("connect database false"); 
mysql_ query("SET NAMES $ POST[select1]"): // 设 置 编码 格式 
/| 和 如果 创 建 数据 表 成 功 
imysql_query("create table $_POST[n](id int(4) auto_increment primary key):"){ 
/输出 提示 


echo "<script>alert(' 创 建 数 据 表 成 功 ):location href='index.php?id=2':</script>"; 
} 
Jelse{ 
echo "<script>alert( 请 选择 编码 格式 );</script>"; 
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kk 
jelsef 

echo "<script>alert( 数 据 表 名 称 不 能 包含 特殊 字符 或 汉字 :</scripf>": 
1 


} 
> 


图 秘笈 心 法 
心 法 领悟 378: 创建 数据 表 的 注意 事项 。 
创建 数据 表 时 ， 系 统 要 求 至 少 包含 一 个 字段 ， 空 数据 表 是 不 允许 创建 的 。 


高 级 
趣味 指数 : 傅 人 视 傅 诊 : 


图 实例 说 明 


数据 表 是 由 多 个 字段 组 成 的 ， 字 段 又 分 为 是 什么 数据 类 型 、 是 否 设置 主键 、 是 否 可 以 为 室 、 选 择 设置 编码 
格式 等 。 本 实例 通过 SQL 语句 实现 动态 创建 数据 字段 ， 运 行 结果 如 图 8.48 所 示 。 


[DEE | | 
m3 ms Fa 


图 8.48 动态 创建 MySQL 数据 库 字 段 


图 关键 技术 


本 实例 实现 动态 创建 数据 字段 的 SQL 语句 的 代码 如 下 : 


$sqll = "create table tb_demo035("; 


编写 脚本 文件 ndex.php。 首 先 ， 连 接 数据 库 服务 器 和 数据 库 。 然 后 ， 读 取 服 务 器 中 存储 的 数据 库 ， 根 据 选 
择 的 数据 库 ， 创 建 form 表单 ， 提 交 数 据 表 名 称 、 字 段 名 称 和 编码 格式 。 最 后 ， 获 取 表 单 中 提交 的 数据 ， 执 行 数 
据 表 中 字段 的 添加 操作 ， 其 核心 代码 如 下 : 


if($_POST[sub1] ){ / 单 击 按钮 
/| 拼接 字符 串 
$sq=""$ POSTftextl id] ." "."int(".$ POST[text3 id].")"." "."primary key auto increment"; 
$_SESSION[sq] = $sq; // 保 存 于 session 中 
for($b=0:$b <$_SESSION[id]:$b++){ /循环 语句 
if($_POST["select type".$b] — "1"){ /确定 类 型 
echo "<script>alert( 请 选择 数据 类 型 ):location href~'index.php';</script>"; 
jelsef 
/判断 字段 长 度 值 
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if($_ POST["length".$b] = 


"||$_POST["length".$b] != "长 度 / 值 "){ 


iftpreg_match("/\d/".$_POST["length".$b]){ /正则 表达 式 
$sql="".$ POST["n".$b].” ".$_POST["select type".$b]."(".$_POST["length".$b].")"." ".$_POST["select".$b].","; 
$_SESSION['sql'.$b] = $sql: /保存 于 session 

jelse{ 
echo "<script>alert( 不 是 一 个 数字 '):location href-'index.php':</script>"; 

} 

+ 
} 
$sqll = "create table tb_demo035("; /定义 字符 串 
S$sqD =");"; /定义 字符 串 
Sarray = arrayO; /定义 数组 
for(d=0:$d<$ SESSION[id]:Sd+H){f /循环 语句 
array_push($array,$_SESSION[sql.$d]); 
» 
$arr = implode($array); // 合 并 字符 串 
$s = $sqll.$arr.$sq.$sql2; // 合 成 sql 语句 
/| 连接 MySQL 
$conn = mysql connect("localhost","root","111") or die("connect mysql false"); 
// 连 接 数 据 库 。 
mysql_select_db("db_database08",$conn) or die("connect database false"); 
mysql_query("set names utf8"); // 设 置 编码 
if(mysql_query($s){ /| 执行 创建 
echo "<script>alert( 动 态 创建 数据 字段 成 功 );:</script>"; 
Jelse{ 
echo "<script>alert( 以 存在 数据 库 )</script>"; 
3 
中 
?> 


秘笈 心 法 

心 法 领悟 379: 动态 创建 字段 还 可 以 使 用 SQL 中 的 alter table 语句 实现 。 

动态 创建 字段 只 是 向 指定 的 数据 表 中 添加 新 的 字段 及 字段 属性 值 。 修 改 表 的 操作 语句 为 alter table， 主 要 实 
现 对 数据 表 结 构 进 行 操作 ， 也 可 以 对 表 中 的 列 进行 添加 或 删除 、 创 建 或 撤销 索引 、 更 改 现 有 列 的 类 型 或 更 改 列 
或 表 的 名 称 及 修改 表 的 注释 和 类 型 。 该 语句 的 格式 如 下 : 

alter [ignore] table table_name action list ; 

参数 说 明 : 

该 语句 允许 指定 多 个 动作 ， 其 动作 间 使 用 逗号 分 隔 ， 每 个 action 表示 对 表 的 一 个 修改 。 它 不 仅 能 够 同时 执 
行 多 个 修改 操作 ， 还 可 以 同时 将 所 有 varchar 列 更 改 为 char 列 ， 从 而 实现 将 行 可 变 的 表 更 改 为 行 定 长 的 表 。 在 


表 8.2 alter table 语句 的 常用 功能 


功 能 示例 语句 说 阴 
对 表 重 新 命名 ”|alter table table_name rename as new_table_name :| 只 需 给 出 原 表 名 和 新 表 名 即 可 
该 语句 将 s_table 表 中 的 列 id 由 smallint unsigned 类 型 更 
改 为 int unsigned 类 型 
第 3 条 语句 中 , 使 用 change 既 更 改 了 id 的 类 型 , 又 重新 
将 记 命 名 为 sid 
在 字符 串 中 ， 定 长 的 列 一 般 比 变 长 的 列 处 理 得 快 。 如 语 


alter table s_table modify id int unsigned ; 
更 改 列 的 类 型 |alter table s_table change id int unsigned : 
alter table s_table change id sid int unsigned : 


| altertable s_ table modify user char (30) : 名 中, s_table 中 列 user 的 类 型 是 varchar, 将 其 转换 为 定 
长 的 char 列 ， 可 提高 查询 的 效率 

将 字符 串 列 从 定 虽然 字符 串 使 用 定 长 的 行 查询 效率 高 ， 但 是 却 占用 了 很 

长 转 为 可 变 长 alter table s_table modify user varchar (30) : 多 空间 ， 而 使 用 变 长 的 字符 串 列 却 能 够 节省 空间 ， 使 转 


517 


A 


8.6 SQL 查询 语句 


本 节 将 介绍 在 PHP 语言 中 ， 如 何 运 用 SQL 语言 中 的 查询 语句 查询 数据 库 中 的 数据 。 


高 级 | 


趣味 指数 : 请 王 请 请 


图 实例 说 明 

在 实际 的 项 目 开发 过 程 中 , 经常 需 要 在 数据 库 中 建立 一 些 数 值 型 字段 保存 信息 ， 例 如 商品 的 数量 、 价 格 等 。 
本 实例 将 通过 在 数据 库 中 查询 库存 剩余 量 大 于 100 的 商品 信息 ， 来 说 明 查 询 数值 型 数据 的 方法 。 运 行 本 实例 ， 
如 图 8.49 所 示 ， 图 中 显示 的 为 库存 量 大 于 100 的 商品 。 


日 其 
《PR 范 鲍 大 全 》 2010-07-19 
《JAV4 范 例 大 全 》 2010-07-19 
《V8 范例 大 宇 》 2010-07-19 
《Cr+ 范例 大 全 》 2010-07-19 


图 8.49 大 于 100 的 数据 


本 实例 实现 查询 大 于 100 的 数据 的 SQL 语句 的 代码 如 下 : 


select * from tb_demo036 where sum > 100; 
图 设计 过 程 


编写 index.php 文件 。 建 立 数据 库 连 接 ， 显 示 所 有 满足 库存 量 大 于 100 的 商品 信息 ， 代 码 如 下 : 


<2php 

ifS_POST[sub]){ // 单 击 按钮 
Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false”): /连接 数据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 
Srs = mysql_query("select * from tb_demo036 where sum > 100"): // 返 回 结果 集 

> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 
while($rst = mysql_fetch row(Srs)){ 1/ 循环 输出 
echo "<tr><td background- pic/head.JPG>".S$rst[0]."</td><td background='pic/head.JPG>".Srst[1]."</td><td 
background='pic/head.JPG>".$rst[2]."</td><td background='pic/head.JPG>".$rst[3]."</td></tr>"; 
} 


} 
> 


力 秘笈 心 法 


心 法 领 司 380: 列举 相关 的 查询 谓词 
本 实例 的 SQL 查询 语句 包含 谓词 “>”， 查 询 谓词 还 包括 “=”、“<>”、“!=”、“>”、“<”、<>=”、 
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“=<”、“I<” 和 “1>”。 


ee 语 辣 请 疝 : ol 


图 实例 说 明 


对 字符 串 进 行 查询 是 项 目 开发 过 程 中 应 用 几率 最 高 的 查询 ， 并 且 这 种 查询 经 常 与 通配符 配合 使 用 实现 信息 
的 匹配 查询 。 运 行 本 实例 ， 如 图 8.50 所 示 。 


习 ED 
加 韦 多 人 
1 《PP 反例 大 全 》 ht a 19 


图 8.50 查询 字符 串 


杰 询 字符 出 y Ye 


图 关键 技术 


使 用 SQL 语句 可 以 对 字符 串 进行 完全 匹配 查找 和 模糊 查找 ， 如果 对 字符 串 进行 匹配 查找 则 直接 用 等 号 作为 
查询 条 件 的 连接 谓词 ， 如 果 对 字符 串 进 行 模糊 查找 则 用 like 关键 字 作 为 连接 谓词 。 下 面 将 通过 具体 实例 讲解 如 
何 实现 对 字符 串 的 查找 。 

(1) 从 学 生成 绩 表 〈tb_score) 中 查询 所 有 名 为 “小 刘 ” 的 学 生 信 息 ， 其 中 学 生 姓 名 字段 为 sname。 
select * from tb_score Where sname= 一 小 刘 ' 


(2) 从 学 生 表 〈tb_student) 中 查询 所 有 姓 “ 刘 ”的 学 生 信息 ， 其 中 学 生 姓名 字段 为 sname。 


select * from tb_student where sname like J%%6" 


(3) 从 职工 表 (tb_worker) tli “程序 员 ” 的 员工 信息 ， 其 中 员工 职务 字段 为 zhiwu。 


select + from tb_worker where zhiwu like %6 程 序 


(4) 从 图 书信 息 表 (tb_book) 中 查询 所 有 PHP 类 相关 图 书 ， 其 中 书 名 字段 为 bookname。 


select * from tb_book where bookname like %PHP%6' 


图 设计 过 程 


编写 index.php 文件 ， 连 接 MySQL 数据 库 ， 显 示 查 询 到 的 图 书信 息 ， 代 码 如 下 : 


<?php 

ifS_POST[sub]){ / 单 击 按钮 
S$conn = mysql_connect("localhost","root"."111") or die("connect mysql false”); /连接 MySQL 
Imysql_select_db("db_database08".Sconn) or die("connect database false"): // 连 接 数据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 
/返回 结果 集 


Srs = mysql_query("select + from tb_demo036 where name like 9%6S_POST[select]9%b": 
?> 

<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 

while($rst = mysql_fetch row(Srs)){f /循环 输出 

echo "<tr><td background- pic/head JPG’>".$rst[0]."</td><td background=-'pic/head.JPG>".Srst[1]."</td><td 

background- pic/head.JPG>".Srst[2]."</td><td background='pic/head JPG>".$rst[3]."</td></tr>"; 

} 


> 
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力 秘笈 心 法 


心 法 领情 381: 对 关键 字 like 的 评价 。 


对 字符 串 进行 模糊 查找 可 以 使 用 like 关键 字 。like 关键 字 十 分 重要 ， 几 乎 在 所 有 网 站 的 站 内 搜索 模块 中 都 
有 其 身影 。 


图 实例 说 明 


对 日 期 型 数据 进行 查询 在 商业 网 站 中 得 到 了 广泛 的 应 用 ， 例 如 查询 员工 的 出 生日 期 、 商 品 的 进货 时 间 等 。 


本 实例 将 在 图 书信 息 表 中 查询 图 书 出 版 日 期 为 “2010-07-19” 的 图 书信 息 ， 


运行 本 实例 ， 


如 图 8.51 所 示 。 


壹 询 J 昌 期 型 致 所 


书 多 
《PHP 范 例 大 全 》 
《JAVA 范 鹿 大 会 》 
《YB 范例 大 宇 》 
《C++ 范例 大 全 》 


2nI-0-19 
20I-07-19 
20F0-19 
21F07-19 


图 8.51 查询 日 期 型 数据 


本 实例 实现 查询 日 期 型 数据 的 SQL 语句 的 代码 如 下 : 


Select * from tb_demo036 where date ='2010-07-19"; 


查询 tb_demo036 数据 表 中 所 有 时 间 date 等 于 “2010-07-19” 的 数据 。 


力 设计 过 程 


建立 jndex.php 文 件 ,连接 MySQL 数据 库 , 当 单 击 显示 数据 按钮 时 ,程序 会 自动 显示 出 版 日 期 为 <2010-07-19” 


的 所 有 图 书 ， 代 码 如 下 : 


这 $_POST[sub]){ 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false"): 
mysql_select_db("db_database08",$conn) or die("connect database false”); 
mysql_query("set names utf8"); 
Srs = mysql_query("select + from tb_demo036 where date ="'2010-07-19"); 

> 


// 单 击 按钮 
/连接 MySQL 
/连接 数据 库 
/设置 编码 格式 
/返回 结果 集 


<table width="580px"><tr><td background="pic/head JPG">ID</td><td background-"pic/head JPG"> 书 名 </td><td 


background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 <td></tr> 
<?php 
和 mysql fetch_row($rs){ 

‘<tr><td background='pic/head.JPG>".$rst[01."</td><td ba 
ee Srst[2]."</td><td background-pichead.JPG>， 
} 
> 


图 秘笈 心 法 
心 法 领悟 382: 不 同 数据 库 查询 日 期 型 数据 存在 差异 。 
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"Srst[3]."</td></tr>"; 


/循环 输出 结果 
>" Srst[11."</td><td 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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E26 py 
利用 荧 攻 本 询 字符 中 交角 
/WAM AM 
| [=5] 

书包 价格 日 期 

1 PRP 开发 评注 宝安 a0 元 2n m17 

: 8 元 2010-07 

而 1 于 30 WT 

11 1 先 30 M7 

2 1 2010-07-17 

3 1 于 ZH OT 


图 8.55 利用 变量 查询 字符 串 数据 


图 关键 技术 


利用 变量 实现 数据 的 查询 , 经 常 需要 通过 表单 提交 、 获取 要 查询 的 内 容 , 并 将 该 内 容 赋予 某 变量 后 传 入 SQL 
语句 执行 查询 ， 并 通过 $_POST[] 方 式 进行 接收 。 

本 实例 中 实现 按 图 书 名 称 进行 匹配 查询 的 代码 如 下 : 

$sql=mysql_query("select * from tb_demo031 where bname like '%$_POST[text] 9%%°"); 

由 于 传 入 SQL 语句 的 参数 为 字符 型 数据 ， 所 以 应 在 传 入 参数 的 两 侧 加 上 单 引号 表示 该 数据 为 字符 型 ,否则 
程序 将 发 生 类 型 不 匹配 的 错误 。 当 然 该 语句 还 可 以 写成 如 下 形式 : 

$sql=mysql_query("select * from tb_demo031 where bname like '%6*.$_POST[text]."%",Sconn); 

这 是 因为 PHP 中 的 字符 串 有 两 种 表示 形式 ， 一 种 是 可 以 将 字符 串 用 单 引号 括 起 来 ， 另 一 种 是 将 字符 串 用 双 
引号 括 起 来 。 如 果 采 用 第 二 种 表示 形式 ，PHP 变量 可 以 直接 写 在 该 字符 串 中 ， 系 统 并 不 会 将 该 变量 看 作 是 字符 
串 的 一 部 分 ， 还 是 将 其 当 作 PHP 的 合法 变量 。 


图 设计 过 程 


编写 文件 index.php， 设 计 网 页 框架 ， 连 接 MySQL 数据 库 ， 根 据 提示 当 单 击 “ 查 看 ”按钮 时 ， 将 传 入 的 字 
符 串 应 用 于 SQL 语句 中 ， 实 现 模 糊 查询 ， 代 码 如 下 : 


<?php 
if($_POST[sub]){ / 单 击 “ 查 看 ”按钮 
这 $_POST[text] 一 "||$_POST[text] 一 "输入 图 书 名称 "){ // 当 文本 框 为 空 或 初始 值 
echo "<script>alert( 输 入 图 书 名 ;</script>"; /输出 提示 
Jelse{ 
S$conn = mysql_connect("localhost"."root"."111") or die("connect mysql false"): /连接 MySQL 
/连接 数据 库 
mysql_select_db("db_database08",$conn) or die("connect database false”): 
mysql_query("set names utf8"); // 设 置 编码 格式 
Srs = mysql_query("select * from tb_demo031 where bname like '%$_POST[text]%%"); /返回 结果 集 
echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td ”background="pic/head.JPG"> 日 期 </td></tr>'; /循环 输出 结果 


while(Srst = mysql_fetch_array(Srs)){ 
?> 


<tr><td background="pic/head JPG"><?php echo Srstfol:?></td><td background="pic/head. JPG"><?php echo Srstf11:?></td><td 
background="pic/head JPG"><?php echo Srst[2]:?></td><td background="pic/head. JPG"><?php echo Srst[3]:?></td></tr> 
php 


} 


} 


i 
> 


力 秘笈 心 法 


心 法 领悟 386: 完全 匹配 的 方法 。 
本 实例 中 使 用 了 完全 匹配 符 “%%”， 表 示 查 询 字符 串 可 以 出 现在 任何 位 置 。 
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图 实例 说 明 


在 图 书 管理 系统 中 ， 经 常 需要 查询 前 n 本 书 的 详细 信息 。 运 行 本 实例 ， 如 图 8.56 所 示 ， 首 先 在 图 中 的 文本 
框 中 输入 要 查询 的 记录 个 数 ， 单 击 “ 查 看 ”按钮 即 可 按 要 求 查 找到 满足 条 件 的 图 书信 息 。 


要 询 的 N 符 记录 
本 加 
ID 书 名 价格 日 其 
1 PRP 开 发 实战 宝典 80 元 2010-07-17 
2 8 开发 实战 裤 实 BD 元 2010-0T-17 


图 8.56 查询 前 n 条 数据 


图 关键 技术 


关键 字 limit 是 MySQL 数据 库 的 扩展 部 分 ,利用 它 可 以 实现 查询 从 指定 位 置 开始 满足 一 定 条 件 的 n 条 记录 ， 
如 果 n 超出 表 的 范围 ， 则 只 显示 从 指定 位 置 开始 到 表 结 束 的 所 有 记录 。 本 实例 通过 如 下 代码 实现 查找 指定 的 前 
mm * from tb_student where classname like 96".Sclassname "96 order by userid desc limit 0.Snumber ",Sconn); 
图 设计 过 程 
pe index.php 文件 ， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 显 示 前 n 条 记录 
代码 如 下 : 


<?php 
ifS_POST[sub]){ / 单 击 “ 查 看 ”按钮 
这 $_POST[text] 一 "||$_POST[text] 一 "输入 图 书 名 称 "){ /1/ 判 断 文本 框 是 否 为 空 或 初始 值 
echo "<script>alert( 输 入 图 书 名"):</script>"; WJavaScript 提示 
Jelse{ 
iftpreg_match("/\d/",$_POST[text]){ /正则 表达 式 过 滤 字 符 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false”): // 连 接 数 据 库 
mysql_query("set names utf8"): // 设 置 编码 格式 
Srs = mysql_query("select * from tb_demo031 limit $ POST[text]"): // 返 回 结果 集 


echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head JPG"> 日 期 </td></tr>': 

while(Srst = mysql_fetch_array(Srs)){ /循环 输出 
> 


<tr><td background—"pic/head. JPG"><?php echo S$rst[0]:?></td><td background=-"pic/head JPG"><?php echo $rst[1]:2></td><td 
background="pic/head JPG"><?php echo S$rst[2]:?></td><td background="pic/head. JPG"><?php echo S$rst[31:7></td></tr> 
<?php 


} 
jelsef 

echo "<script>alert( 输 入 的 不 是 一 个 数字 ?:</scripf>": 
天 
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图 秘笈 心 法 


心 法 领悟 387: limit 语句 的 优点 。 
limit 语句 与 其 他 语句 , 例如 order by 等 语句 联合 使 用 , 会 使 用 户 的 SQL 语句 千变万化 , 从 而 使 程序 非常 灵活 。 


a le 2 | 


国 实例 说 明 
对 后 n 条 记录 的 查询 在 实际 项 目 开发 过 程 中 也 经 常 被 用 到 ， 例 如 查询 最 后 添加 到 数据 库 中 的 n 条 信息 。 运 
行 本 实例 ， 如 图 8.57 所 示 ， 显 示 数 据 库 最 后 的 若干 数据 。 


查询 后 N 傣 数据 


[ss] 


日 期 

2010-07-17 
2010-07-17 
2010-07-17 
201 017 
2010-07-17 


图 8.57 查询 后 n 条 数据 


图 关键 技术 

与 查询 前 n 条 记录 相 比 ， 查 询 后 mn 条 记录 首先 应 对 表 中 的 所 有 记录 进行 降序 排列 ， 之 后 通过 关键 字 limit 指 
定 要 查询 的 记录 个 数 。 对 记录 升序 排列 可 以 在 SQL 语句 中 添加 如 下 语句 实现 : 

order by 字段 名 (或 order by 字段 名 asc) 

对 记录 降序 排列 可 以 在 SQL 语句 中 添加 如 下 语句 实现 : 

order by 字段 名 desc 

本 实例 实现 查询 后 n 条 数据 的 SQL 代码 如 下 : 

select * from tb_demo031 order by id desc limit $_POST[text]: 
图 设计 过 程 

编写 index.php 文件 ， 通 过 <table> 标 签 建立 网 页 架构 ， 引 入 头 部 图 片 ， 开 启 MySQL 服务 并 连接 MySQL 数 
据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 显 示 后 几 条 信息 ， 代 码 如 下 : 


这 $_POST[sub]){ / 单 击 “ 查 看 ”按钮 
if($ ] Pl 上 1$_POST[text] 一 "输入 图 书 名 称 "){ /判断 文本 框 
echo "<script>alert( 输 入 图 书 名");</script>"; /JavaScript 提示 
jelsef 
这 preg_match(wvd/".S POST[textD){ /正则 表达 式 验证 
Sconn = mysql_connect("localhost","root"."111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08".Sconn) or die("connect database false"): // 连 接 数据 库 
mysql_ query("set names utf8"); /设置 编码 


S$rss =mysql_query("select * from tb_demo031 order by id desc limit $ POST[text]"); /返回 结果 集 

echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td = background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td ”background="pic/head.JPG"> 日 期 </td></tr>; 

while($rst = mysql_fetch_array($rss){ /| 循环 输出 
> 


<tr><td background="pic/head.JPG"><?php echo S$rst[01:?></td><td background="pic/head JPG"><?php echo S$rst[11:7></td><td 
background="pic/head JPG"><?php echo Srst[2]:?></td><td background="pic/head. JPG"><?php echo S$rst[3]:?></td></tr> 
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<2php 有 
jelsef 
echo "<script>alert( 和 输入 的 不 是 一 个 数字 ?:</script>": 
) 
} 
} 
> 
图 秘笈 心 法 
心 法 领悟 388: 对 SQL 语句 的 评价 。 
灵活 运用 SQL 语句 ， 会 让 用 户 觉得 很 多 看 起 来 复杂 的 程序 其 实 很 简单 。 
高 级 | 
趣味 指数 : 二 寅 寅 诬 


国 实例 说 明 


PHP 中 实现 分 页 显示 的 原理 就 是 从 指定 位 置 开始 显示 n 条 记录 ， 下 面 通过 本 实例 讲解 如 何 实现 这 种 显示 方 
式 。 运 行 本 实例 ， 如 图 8.58 所 示 。 


车 入 和 8D 赂 入 要 而 邓 殉 [ss】 
书 名 价格 日 期 


|Y8 开 发 实战 宝典 Ri 元 2010-07-17 
TV 开发 实 臧 宝 下 19 克 20F037 
JAVAE6 开 发 实 芭 宇 趴 LE 


图 8.$8 查询 从 指定 位 置 的 n 条 记录 


图 关键 技术 


实现 从 指定 位 置 开始 查询 满足 条 件 的 n 条 记录 ， 主 要 应 用 MySQL 的 扩展 关键 字 limit， 该 关键 字 的 使 用 格 
式 如 下 : 
select 要 查询 的 字段 from 表 名 where 查询 的 条 件 limit 满足 条 件 的 起 始 位 置 .记录 的 个 数 

关键 字 limit 后 有 两 个 参数 ， 第 一 个 参数 用 于 指定 要 满足 条 件 记 录 的 起 始 位 置 ， 第 二 个 参数 指定 查询 结果 中 
满足 条 件 的 记录 个 数 。 

本 实例 实现 查询 指定 位 置 的 nn 条 记录 的 SQL 语句 如 下 

select * from tb_demo031 limit $ POST[text1], $_POST[text]: 

图 设计 过 程 

创建 ndex.php 文件 ， 编 写 网 页 框架 ， 开启 MySQL 服务 器 并 连接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 

显示 指定 位 置 的 n 条 记录 ， 代 码 如 下 : 


这 $_POST[sub]){ // 单 击 按钮 
1/ 判断 文本 框 信息 
这 $_POST[text] 一 "||$_POST[text] 一 "输入 图 书 名称 " || $_POST[text1] 一 "||$_POST[text1] 一 "输入 查询 条 数 "){ 
echo "<script>alert( 输 入 图 书 名"):</script>"; /NJavaScript 提示 
jelsef 
这 preg_match("/d/".$_POST[textD)){ // 正 则 表达 式 验 证 
if(preg_match("N\d/".$_POST[text1D){ // 正 则 表达 式 验证 
Sconn = mysql_connect("localhost","root"."111") or die("connect mysql false"); /连接 MySQL 
mysql_ select_db("db_database08".$conn) or die("connect database false"): // 连 接 MySQL 服务 器 
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图 关键 技术 


在 SQL 语句 中 ， 对 指定 范围 内 的 数据 进行 查找 可 以 通过 以 下 两 种 方式 实现 ， 第 一 种 方式 ， 可 以 通过 关键 字 
between...and... 实 现 ， 语 法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 between 初始 值 and 终止 值 


第 二 种 方式 ， 可 以 通过 比较 运算 符 实现 ， 语 法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 > 初始 值 and 字段 名 < 终止 值 
图 设计 过 程 
创建 index.php 文件 ， 启 动 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 看 ”按钮 时 ， 显 示 指定 时 间 段 
的 数据 ， 代 码 如 下 : 


<?php 
if($_POST[sub){ /| 单 击 “ 查 看 ”按钮 
1/ 判断 文本 框 信息 
这 $_POST[textl] 一 "||$_POST[text1] 一 "输入 开始 日 期 "||$_POST[text] 一 "||$_POST[text] 一 "输入 结束 日 期 "){ 
echo "<script>alert( 请 输入 日 期 );</script>"; WJavaScript 提示 
Jelse{ 
/验证 日 期 格式 的 正则 表达 式 


这 preg match("(f0-91{3}f1-910-91f23f1-9110-91f13T1-9110-91f23I[1-9110-9143?D-(((of13578]I1f0-2D)-(of1-91If12110-913TolD)K(o4691110)-(o[1-91I121T 
0-9]30))K02-(0[1-9]I[1][0-9]P[o-8]))/",$_POST[textD)){ 


$conn = mysql_connect("localhost","root","111") or die("connect mysql false”); /连接 MySQL 

mysql_select_db("db_database08",$conn) or die("connect database false"); // 连 接 MySQL 数据 库 

mysql_ query("set names utf8"); 1/ 设置 编码 格式 

Srss = mysql_query("select * from tb_demo047 where date between '$_POST[textl] and '$ POST[text]' order by date"); 
// 返 回 结 果 集 


echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td 。 background="pic/head.JPG"> 日 期 </td></tr>': 

while(Srst = mysql_fetch_array(Srss)){ /循环 输出 结果 
> 


<tr><td background="pic/head. JPG"><?php echo Srst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head. JPG"><?php echo S$rst[3]:?></td></tr> 
<?php 

} 


jelsef 
echo "<script>alert( 日 期 格式 错误 ! 正确 格式 为 ，xxxx-xx-xx);</script>": /JavaScript 提示 信息 
} 


» 
> 


力 秘笈 心 法 


心 法 领悟 391: 正则 表达 式 的 限制 。 
本 实例 所 使 用 的 正则 表达 式 只 是 对 平年 ， 即 一 年 365 天 的 正则 表达 式 验 证 。 


图 实例 说 明 
在 一 些 图 书 管理 系统 中 ， 经 常 需要 按 年 、 月 、 日 查询 图 书 的 出 版 信息 。 运 行 本 实例 ， 如 图 8.61 所 示 ， 首 先 
在 图 中 文本 框 中 输入 要 查询 的 月 份 ， 然 后 单 击 “ 查 找 ” 按 钮 ， 即 可 将 该 月 份 出 版 的 图 书信 息 查 找 出 来 。 
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3 
mg mm | I 辆 | 
随和 月 谷 ee 
TD 书 名 价格 日 期 
1 Ce 开发 实 上 成 宝典 78 元 2010-07-11 
8 PRP 范 全 宝典 78 元 2010-07-17 
9 Wa 范例 主 册 78 天 2010-07717 
10 。 pRP 范 全 宝典 78 元 2010-07-17 


图 8.61 按 月 查询 统计 数据 


图 关键 技术 

本 实例 实现 按 月 查询 统计 数据 的 SQL 语句 如 下 : 

select * from tb_demo047 where month(date) ='$_POST[text1] order by date: 
图 设计 过 程 

创建 脚本 文件 index.php。 通 过 <table> 标 签 建 立 网 页 框架 ， 引 入 网 页 头 部 图 片 文件 ， 开 启 MySQL 服务 并 连 
接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 显 示 查 询 信息 ， 代 码 如 下 : 


<?php 
ifS_POST[sub])f // 单 击 “ 查 看 ”按钮 
这 $_ POST[textl] 一 "1 $_POST[textl] 一 "输入 月 份 "){ 1/ 判 断 文 本 框 信息 
echo "<script>alert(' 请 输入 月 份 );</script>": /Javascript 提示 
jelse{ 
if(preg_match("/[^A-Za-z_]/",$_POST[text1]){ // 正 则 表达 式 验 证 文本 框 信息 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false”); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die("connect database false"); // 连 接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 集 


Srss = mysql_query("select * from tb_demo047 where month(date) ='$ POST[textl] order by date”"); 
echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td ”background="pic/head.JPG"> 日 期 </td></tr>'; 


while(Srst = mysql_fetch_array(Srss)){ /循环 输出 结果 
> 


<tr><td background="pic/head. JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head. JPG"><?php echo S$rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3];?></td></tr> 
<Iphp 


} 
jelse{ 

echo "<script>alert( 月份 格式 错误 ! 正确 格式 为 :xx);</script>"; 
} 


} 
> 


图 秘笈 心 法 


心 法 领悟 392: 与 年 、 月 、 日 相关 的 查询 函数 。 

SQL 语言 中 提供 了 如 下 函数 ， 利 用 这 些 函 数 可 以 很 方便 地 实现 近年、 月 、 日 进行 查询 。 
year(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 公元 年 份 所 对 应 数值 。 

month(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 月 份 所 对 应 的 数值 。 

day(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 日 期 所 对 应 的 数值 。 
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图 秘笈 心 法 
心 法 领悟 393: 另外 一 种 实现 方式 。 
实现 本 实例 的 SQL 语句 代码 还 可 以 使 用 另外 一 种 方式 表达 ， 如 下 所 示 : 


select * from tb_demo047 where price !< $_POST[text1] order by price; 


复 记录 高 级 
趣味 指数 : 请 祝 亢 亢 ， 


实例 394 


力 实例 说 明 


在 某 些 管理 系统 中 ， 有 重复 记录 是 不 可 避免 的 ， 不 在 前 台 显示 重复 的 记录 可 以 通过 SQL 语言 的 关键 字 
distinct 实现 。 运 行 本 实例 ， 如 图 8.63 所 示 ， 图 书信 息 中 价格 相同 的 信息 将 被 删除 。 


查询 结 困 不 显示 重 笃 记录 


图 8.63 去 掉 重 复 项 输出 


图 关键 技术 

SQL 语句 中 ， 查 询 结果 中 不 显示 重复 记录 可 以 通过 关键 字 distinct 实现 ， 该 关键 字 使 用 的 格式 如 下 : 

select distinct 字段 名 from 表 名 where 查询 条 件 

distinct 关键 字 可 以 在 查询 结果 中 去 除 重复 行 ， 与 其 对 应 的 还 有 关键 字 all。 在 SQL 语句 中 加 入 关键 字 all， 
表示 显示 所 有 的 记录 ， 如 果 SQL 语句 中 这 两 个 关键 字 都 不 加 ， 则 查询 结果 将 显示 所 有 的 记录 。 
力 设计 过 程 


创建 脚本 文件 index.php， 开 启 MySQL 服务 器 并 连接 MySQL 数据 库 ， 单 击 按钮 显示 信息 ， 核 心 代码 如 下 : 


<?php 
这 $_POST[submitD){ / 单 击 按钮 
这 $_POST[text] != "|| $_POST[text] != "输入 图 书 价格 "){ /1/ 判 断 文本 框 信息 
if(preg_match("/[^a-zA-Z_]/".$_POST[text]){ /正则 表达 式 验 证 信息 
/返回 结果 集 
Srs = mysql_query("select distinct * from tb_demo031 where price ='$ POST[text] 元 ""): 
> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td background="pic/head.JPG"> 价 格 
</td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 

while(Srst = mysql_fetch row($rs){ /循环 输出 结果 


> 
<tr><td background—"pic/head JPG"><?php echo $rst[0]:?></td><td background-"pic/head JPG"><?php echo $rst[1]:2></td><td 
background="pic/head.JPG"><?php echo Srst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[3]:?></td></tr> 


<?php 
jelsef 
echo "<script>alert( 答 入 不 是 一 个 数值 );</script>": /WJavaScript 提 示 
} 
jelsef 
echo "<scripf>alert( 请 输入 信息 );</scripfP>": /WJavaScript 提 示 
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} 
} 


> 


图 秘笈 心 法 


心 法 领悟 394: 使 用 关键 字 distinct 的 注意 事项 。 
SQL 语句 中 的 关键 字 distinct 必须 与 where 子 句 联合 使 用 ， 否 则 输出 的 信息 不 会 有 变化 。 


高 级 | 
起 呆 挤 多， 机 页 页 


图 实例 说 明 


在 开发 一 些 网 站 时 ， 有 时 需要 查找 不 满足 一 定 条 件 的 所 有 记录 ， 比 如 在 人 事 系统 中 查找 所 有 不 姓 刘 的 员工 
信息 。 运 行 本 实例 ， 如 图 8.64 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 不 想 显 示 的 图 书 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， 
即 可 将 所 有 不 为 该 名 称 的 图 书 显示 出 来 。 


NOT 与 谓词 进行 组 全 等 传 的 要 询 


大 [se) 
下 书 各 价格 日 期 

Y8 开 发 实战 宝典 80 元 2010-07-17 
》 jiVi 开 发 实战 室 突 ET 
x TT 
了 7 县 2TF07-17 
4 


0 天 in0P0217 
和? 阮 201 E07 
1 阮 2N 07 


图 8.64 not 与 谓词 进行 组 合 条 件 查询 


力 关键 技术 


not 与 谓词 进行 组 合 所 形成 的 表达 式 分 别 是 not between..….and...、is not null 和 not in, 这 3 种 组 合 的 详细 说 明 
如 下 : 
(1) not between...and...: 
where 字段 名 not between 查询 范围 开始 值 and 查询 范围 的 结束 值 


该 式 查询 所 有 不 在 该 范围 内 的 记录 ， 这 种 限定 条 件 可 以 改写 成 如 下 格式 : 
where 字段 名 < 查询 范围 的 开始 值 and 字段 名 > 查询 范围 的 结束 什 


(2) is not null 


该 式 根据 所 使 用 的 关键 字 指 定 对 空 值 或 非 空 值 的 搜索 ,如 果 有 任何 操作 数 是 NULL, 则 表达 式 取 数 为 NULL。 


(3) notin 
该 式 根据 使 用 的 关键 字 是 包含 在 列表 内 还 是 排除 在 列表 外 ， 指 定 表达 式 的 搜索 ， 搜 索 表达 式 可 以 是 常量 或 
列 名 ， 而 列 名 可 以 是 一 组 常量 ， 但 更 多 情况 下 是 子 查 询 。 


设计 过 程 
编写 ndex php 文件 在 文本 框 中 输入 内 容 后 ， 单 击 “ 查 看 ”按钮 输出 显示 信息 ， 代 码 如 下 : 


Se mysql_connect("localhost"."root","111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"); // 连 接 数 据 库 
mysql_ query("set names utf8"); /设置 编码 格式 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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序 排列 可 以 在 SQL 语句 的 order by 子 句 中 指定 关键 字 desc。 实 现 多 条 件 查询 也 是 通过 order by 字句 实现 的 ， 只 


是 多 个 限定 条 件 之 间 应 用 逗号 进行 分 隔 ， 例 如 : 
select 字段 名 from 表 名 where 查询 条 件 order by 字段 1 asc, 字段 2 desc…… 


力 设计 过 程 

创建 脚本 文件 index.php。 编 写 网 页 框架 ， 开启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 排 序 ” 按 钮 
时 ， 显 示 对 数据 进行 多 条 件 排序 ， 代 码 如 下 : 

<?php 


S$conn = mysql_connect("localhost","root","111") or die("connect mysql false”); /| 连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"): /连接 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 
if($_POST[sub){ /人 单 击 按钮 

Srs = mysql_ query("select * from tb_demo054 order by mount desc.price asc"): /返回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品 </td><td background="pic/head JPG"> 数 量 
</td><td background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 <ltd></tr> 
hp 


while(Srst= mysql fetch_row($rs){ /循环 输出 结果 
<tr><td background="pic/head JPG"><?php echo Srst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1];?></td><td 
background="pic/head. JPG"><?php echo Srst[21:?></td><td background="pic/head.JPG"><?php echo $rst[31]:2></td><td 
background="pic/head.JPG"><?php echo S$rst[4]:?></td></tr> 
php 
} 
二 
> 
也 稚 心 法 


心 法 领悟 398: 使 用 多 条 件 排序 的 注意 事项 。 
对 查询 信息 进行 多 条 件 排序 是 为 了 共同 限制 记录 的 排序 输出 ， 一 般 情况 下 ， 由 于 不 是 单一 条 件 限制 ， 所 以 
在 输出 效果 上 有 一 些 差别 。 


高 级 | 
趣味 指数 : 会 会 会 会 | 


力 实例 说 明 
在 商品 信息 管理 系统 中 ， 经 常 需要 对 商品 的 价格 、 数 量 进行 求 和 ， 然 后 根据 所 求 得 的 值 对 商品 进行 排序 ， 
从 而 实现 商品 的 排序 输出 。 运 行 本 实例 ， 分 别 如 图 8.68 所 示 ， 将 单一 类 型 商品 求 和 并 按 商 品 数量 和 商品 单价 


FI [IE 
马 1300 元 T2010-07-21 和 5950 元 
[ LE 1 LE D1 
6 EEEEE IDD SI 
GE EDITIIEI ED 
| aoe nr 1 


8.68 ”对 统计 结果 进行 排序 
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力 关键 技术 


SQL 语言 中 ， 对 某 字 段 所 有 数据 求 和 可 以 通过 函数 sam0 实 现 ， 该 函数 的 使 用 格式 如 下 : 
sum([al] 字 段 名 ) 或 sum([distinct] 字 有 段 名 ) 


sum 中 的 参数 如 果 为 al 加 字段 名 ， 则 表示 对 该 字段 中 的 所 有 记录 进行 求 和 ， 包 括 重复 记 录 ; 如 果 sum 中 的 
参数 为 distinct 加 字段 名 ， 则 表示 对 该 字段 的 所 有 不 重复 记录 进行 求 和 。 在 select 语句 中 使 用 sum0 函 数 的 格式 
如 下 : 

select sum( 字 段 名) as 新 字段 名 from 表 名 where 查询 条 件 


本 实例 实现 对 统计 结果 排序 的 SQL 语句 如 下 : 

select * from tb_demo054 order by mount desc.price asc: 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 排 序 ” 按 钮 时 ， 显 示 运 行 结 
果 ， 如 图 8.68 所 示 ， 其 代码 如 下 : 


<?php 
Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"): /连接 MySQL 
Imysql_select_db("db_database08",Sconn) or die ("connect database false"): /连接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 
if($_POST[sub]){ // 单 击 按钮 

Srs = mysql_query("select * from tb_demo054 order by mount desc.price asc"); // 返 回 结 果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品 </td><td background="pic/head.JPG"> 数 量 
</td><td background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td><td background="pic/head.JPG"> 总 价值 </td></tr> 


hp 
while($rst = mysql fetch_ row($rs){ /循环 输出 结果 
?> 
<tr><td background="pic/head JPG"><?php echo Srstf0]:?></td><td background="pic/head.JPG"><?php echo $rst[11:7></td><td 
background="pic/head.JPG"><?php echo Srst[2];?> 件 </td><td background="pic/head.JPG"><?php echo Srst[3]:?> 元 </td><td 
background="pic/head.JPG"><?php echo Srst[4];?><td background="pic/head.JPG"><?php echo Srst[2]*Srst[3]:?> 元 </td></td></tr> 
<Iphp 
} 
} 
> 


图 秘笈 心 法 

心 法 领悟 399: 求 和 函数 。 

在 对 数据 库 中 的 数据 进行 计算 时 会 经 常用 到 求 和 函数 ， 使 用 该 函数 可 以 免 去 手动 计算 某 些 数据 的 麻烦 ， 同 
时 也 提高 了 计算 的 效率 和 准确 性 。 


实例 400 


力 实例 说 明 
在 动态 网 站 开发 过 程 中 ， 经 常 要 求 把 某 一 字段 的 内 容 按照 一 定 的 规定 进行 分 组 ， 然 后 将 分 组 后 的 结果 按 某 
字段 进行 统计 求 和 ， 最 终 得 到 查询 结果 。 和 运行 本 实例 ， 如 图 8.69 所 示 ， 单 击 图 中 的 “排序 ”按钮 ， 即 可 实现 
先 对 表 中 的 所 有 商品 的 单价 与 数量 进行 求 和 ， 然 后 按 商 品 ID 进行 统计 。 
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尝 列 致 据 分 组 统 遍 


8.69 单列 数据 分 组 统计 


键 技术 


实现 单列 数据 的 分 组 统计 ， 首 先 需 要 根据 某 字段 进行 分 组 ， 然 后 对 分 组 结果 进行 统计 ， 本 实例 中 实现 单列 
数据 分 组 统计 的 代码 如 下 : 

select id,name,sum(price)as title ,date from tb_demo054 group by id order by title desc; 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 排 序 ” 按 钮 时 ， 显 示 单 列 数 
分 组 统计 结果 ， 如 图 8.69 所 示 ， 代 码 如 下 : 


<?php 

Sconn = mysql_connect("localhost","root","111") or die("connect mysql false”); /连接 MySQL 
mysql_select_db("db_database08",Sconn) or die ("connect database false"): // 连 接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 集 
if($_POST[sub]){ / 单 击 按钮 


Srs = mysql_query("select id.name,sum(price)as title ,date from tb_demo054 group by id order by title desc"); /1/ 返 回 结果 集 


?> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品 </td><td background="pic/head.JPG"> 总 额 
</td><td background="pic/head.JPG"> 日 期 </td></tr> 


while($rst = mysql_fetch_row($rs){ /循环 输出 结果 


< background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1]:?></td><td 
background="pic/head.JPG"><?php echo Srst[2]:?> 元 </td><td background="pic/head. JPG"><?php echo S$rst[3]:?></td></tr> 
<?php 


} 
> 


力 秘笈 心 ; 


心 法 领悟 400: 使 用 分 组 语句 的 注意 事项 。 
当 分 组 语句 group by 和 排序 语句 order by 同时 出 现在 SQL 语句 中 时 ,要 将 分 组 语句 书写 在 排序 语句 的 前 面 ， 
否则 会 出 现 如 图 8.70 所 示 的 错误 。 


高 级 | 
| 允 味 指 雪 : 让 页 | 


力 实例 说 明 


对 商品 销售 结果 进行 统计 时 , 经 常 需要 按 商 品 销售 表 中 的 多 列 进行 分 组 统计 。 运行 本 实例 ,如 图 8.71 所 示 ， 
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单 击 图 中 的 “排序 ”按钮 ， 即 可 将 商品 销售 表 中 的 所 有 同名 商品 按 销 售 数量 和 单价 求 和 并 显示 统计 结果 。 


本 | 本 5 
和 多 列 玛 所 
ED 
m 商品 豆 严 日 期 
4 全 自动 洗 下 机 35500 元 |201 -07-21 
Te 5 DT 
C3 rE 0 
2 袖 波 炉 13500 元 |201 0-07-21 
5 “| 1 0 
3 电网 局 14600 元 |201 0-07-21 


图 8.71 多 列 数 据 分 组 统计 


图 关键 技术 

多 列 数据 的 分 组 统计 与 单列 数据 的 分 组 统计 实现 方式 类 似 ， 只 是 按 多 个 字段 进行 分 组 统计 时 ， 统 计 字段 间 
需 用 逗号 进行 分 隔 ， 例 如 : 

select*, sum( 字 段 D as 新 字段 1 from 表 名 group by 字段 名 where 查询 条 件 

本 实例 中 实现 多 列 数据 分 组 统计 的 代码 如 下 : 

select *.sum(pirce*mount) as title from tb_demo054 group by id order by title desc: 
图 设计 过 程 

编写 index.php 文件 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “排序 ”按钮 时 ， 显 示 如 图 8.71 所 
示 的 内 容 ， 代 码 如 下 : 


<?php 

$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"): // 连 接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 

这 $_POST[sub]){ /人 单 击 按钮 


Srs = mysql_query("select id.name,sum(priceymount)as title ,date from tb_demo054 group by id order by title desc "); /返回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品 </td><td background="pic/head.JPG"> 总 额 
</td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 
while($rst = mysql_fetch_row(Srs)){ 1/ 循环 输出 结果 
<tr><td background="pic/head.JPG"><?php echo $rst[01:?></td><td background="pic/head.JPG"><?php echo $rst[11:2></td><td 
background="pic/head.JPG"><?php echo Srst[2]:?> 元 </td><td background="pic/head. JPG"><?php echo Srst[3]:?></td></tr> 
<?php 
} 
} 
> 


力 秘笈 心 法 


心 法 领悟 401: 使 用 group by 语句 的 注意 事项 。 
group by 语句 后 面 一 般 为 不 是 聚合 函数 的 数列 ， 即 不 是 要 分 组 的 列 。 


图 实例 说 明 
开发 一 个 大 型 的 服务 类 网 站 ， 经 常 需要 建立 多 张 表 ， 并 且 表 与 表 之 问 通过 某 种 关系 建立 关联 。 运行 本 实例 ， 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 8.73 ”对 学 生成 绩 汇总 


力 关键 技术 


SQL 语句 中 ， 对 某 字段 的 所 有 记录 进行 求 和 可 以 通过 函数 sam0 实 现 ， 该 函数 的 使 用 方法 如 下 : 

sum([all | distinct] expression) 

参数 说 明 : 

all: 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 all 或 distinct， 则 表示 对 指 
定 字段 的 所 有 记录 进行 聚集 运算 。 

distinct: 表示 对 指定 字段 的 所 有 非 重 复 记录 进行 求 和 。 

expression: 是 精确 数字 或 近似 数字 数据 类 型 分 类 〈bit 数据 类 型 除外 ) 的 表达 式 。 

sum0 函 数 的 返回 类 型 如 表 8.3 所 示 。 


表 8.3 sum() 函 数 的 返回 结果 


表达 式 结果 返回 类 型 
整数 分 类 int 
decimal 分 类 decimal(38.s) 除 以 decimal(10.0) 
money 和 smallmoney 分 类 mon 
float 和 real 分 类 float 


图 设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “对 学 生成 绩 汇总 ”按钮 时 ， 
显示 如 图 8.73 所 示 的 信息 ， 核 心 代码 如 下 : 
?php 


<?pl 

Sconn = mysql_connect("localhost"."root","111") or die ("connect mysql false"): /连接 MySQL 
Imysql_select_db("db_database08",Sconn) or die ("connect database false"): /连接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 
if($_GET[page] — "1"){ /page 等 于 1 时 


S$rss = mysql_ query("select *,sum(chinese+mathtenglish) as a from tb_demo059 group by name order by a desc "); ” // 返 回 结果 和 集 
> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td background="pic/head.JPG"> 
语文 成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td background="pic/head.JPG"> 英 语 成 绩 </td><td background="pic/head.JPG"> 总 成 
绩 <td></tr> 


while($rst = mysql_ fetch_row(S$rss){ /循环 输出 结果 
> 

<tr><td background=—"pic/head. JPG"><?php echo S$rst[01:2></td><td background="pic/head. JPG"><?php echo Srst[11:?></td><td 
background="pic/head.JPG"><?php echo Srst[21:?></td><td background="pic/head. JPG"><?php echo S$rst[31:2></td><td 
background="pic/head JPG"><?php echo S$rst[4]:?></td><td background="pic/head JPG"><?php echo $rst[5]?></td></tr> 
<?php 

} 

} 
> 


力 秘笈 心 法 


心 法 领悟 403: 对 求 和 函数 sum0 的 理解 。 
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sum0 函 数 主 要 用 于 对 数据 表 字段 求 和 ， 一 般 与 分 组 函数 联合 使 用 ， 但 是 只 有 出 现在 多 表 查 询 之 中 才能 真正 
体现 出 它 的 优势 。 


() 求 学 生 的 平均 成 绩 


图 实例 说 明 


获取 统计 数据 平均 值 的 方法 有 多 种 ， 例 如 可 以 先 求 得 所 有 数据 的 总 和 ， 然 后 再 除 以 总 个 数 ， 而 SQL 语言 
提供 了 专门 求 平均 数 的 函数 avg0。 本 实例 将 利用 该 函数 求 得 学 生成 绩 表 中 各 科 成 绩 的 平均 值 。 运 行 本 实例 ， 如 
图 8.74 所 示 ， 单 击 图 中 “对 学 生成 绩 汇 总 ”按钮 ， 即 可 将 各 科 的 平均 成 绩 显示 出 来 。 


信用 要 下 四 扩 A 人 VG 放下 二 红 


逢 字符 或 王 汇 泛 
wo 学 由 地 名 话 文 成绩 ed 英语 或 
J 构 已 36 50 
J 洛 天 四 六 
中 刘 局 多 加 
‘ 3 oa 0 0 
入 利平 区 庶 计 3. 7300 35.2500 #53, B00 


图 8.74 取得 学 生 的 各 科 平 均 成 绩 


图 关键 技术 

获取 某 字 段 的 所 有 记录 的 平均 值 ， 可 以 通过 函数 avg0 实 现 ， 该 函数 的 使 用 方法 如 下 : 

avg([all | distinct] expression) 

本 实例 实现 利用 avg0 函 数 实现 显示 平均 成 绩 的 SQL 语句 如 下 : 

select avg(chinese),ave(math),ave(english) from tb_demo059; 
力 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 对 学 生成 绩 汇总 ”按钮 时 ， 
显示 如 图 8.74 所 示 的 内 容 。 实 现 此 功能 的 核心 代码 如 下 : 


<?php 

Sconn = mysql_connect("localhost","root"."111") or die ("connect mysql false"): /连接 MySQL 

mysql_select_db("db_database08".Sconn) or die ("connect database false"): // 连 接 MySQL 数据 库 

mysql_query("set names utf8"): // 设 置 编码 集 

if($_GET[page] — "1"){ // 如 果 page 等 于 1. 
Srss = mysql_query("select * from tb_demo059"): /返回 结果 集 

> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td background="pic/head.JPG"> 
语文 成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td background="pic/head.JPG"> 英 语 成 绩 </td></tr> 


while($rst = mysql_fetch row($rss){ /循环 输出 结果 
> 
<tr><td background="pic/head JPG"><?php echo S$rst[0]:?></td><td background="pic/head JPG"><?php echo Srst[1]:?></td><td 
background="pic/head. JPG"><?php echo Srst[2]:?></td><td background="pic/head JPG"><?php echo S$rst[3]:?></td><td 
background="pic/head JPG"><?php echo Srst[4]:?></td></tr> 
<?php 4 
Srts = mysql_query("select avg(chinese).avg(math).avg(english) from tb_demo059"): /返回 结果 集 
Srsth = mysql fetch row(Srts): 
> 
<tr><td background="pic/head.JPG"> 各 科 平 均 成 绩 </td><td background="pic/head.JPG"></td><td background="pic/head.JPG"><?php echo 
Srsth[01:?> </td><td background="pic/head. JPG"><?php echo S$rsth[11:?></td><td background="pic/head.JPG"><?php echo $rsthf11:7></td></tr> 
<?php 


545 


PHP 开发 实战 1200 例 (第 I 卷 ) 


站 
> 


力 秘笈 心 法 


心 法 领悟 404: 格式 化 函数 number fommate0 的 使 用 。 
本 实例 并 没有 对 平均 成 绩 进行 格式 化 , 如 果 用 户 想 对 成 绩 进行 格式 化 , 可 以 使 用 函数 number format0 实 现 ， 
其 格式 为 : 


string number format ( float number [, int decimals]) 
参数 说 明 : 

number: 表示 要 进行 格式 化 输出 的 数字 。 
decimals: 表示 要 保留 的 位 数 。 


in() 求 利润 最 少 的 商品 


图 实例 说 明 
在 销售 管理 系统 中 ， 商 家 会 根据 不 同 商品 的 销售 利润 来 确定 该 商品 的 进货 数量 。 运 行 本 实例 ， 如 图 8.75 所 


示 ， 单 击 图 中 的 “获取 利润 最 小 的 商品 信息 ”按钮 ， 即 可 将 销售 利润 最 小 的 商品 信息 显示 在 图 中 最 后 一 行 


了 月 村 要 四 下 MM 永利 间 六 少 的 高 品 
mi 


奖 相 科 油 间 不 克 商品 信 忆 


i 商品 证 称 。。 进 当 价格 1 元。 请 和 谷村 /元 EE 入 和 期 
电视 1500 60 ET 
于 和 En 30 日 ELE 
了 了 可 ED ED [ 77 
: ET ED ET 
DEREICLR 玫 3 四 


图 8.75 ”利润 最 小 的 商品 输出 

图 关键 技术 

SQL 语言 中 ， 获 取 某 字段 的 最 小 值 可 以 通过 函数 min0 实 现 ， 该 函数 的 使 用 方法 如 下 : 

min([all | distinct] expression) 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 获 取 利 润 最 小 的 商品 信息 ” 
按钮 时 ， 显 示 如 图 8.75 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


$conn = mysql_connect("localhost"."root"."111") or die ("connect mysql false"): /连接 MySQL 

mysql_select_db("db_database08".Sconn) or die ("connect database false"): /1/ 连 接 MySQL 数据 库 

mysql_query("set names utf8"); // 设 置 编码 格式 
/返回 结果 集 


S$rss = mysql_query("select * from tb_demo061"); 
> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品名 称 </td><td background="pic/head.JPG"> 
进货 价格 /元 </td><td background="pic/head.JPG"> 销 售 价格 /元 </td><td background="pic/head.JPG"> 进 货 数 量 / 件 </td><td 
background="pic/head.JPG"> 进 - 


货 日 期 </td></tr> 


while(Srst = mysql fetch row(Srss){ 
> 


<tr><td background—"pic/head. JPG"><?php echo S$rst[0]:?></td><td 
background—"pi 


background="pic/head JPG"><?php echo S$rst[2]:?></td><td 
background="pic/head JPG"><?php echo Srst[4]:?></td><td 


/循环 输出 结果 


JPG"><?php echo Srst[1]:?></td><td 
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<?php 有 
if($_GET[page] — "1"){ /1/ 当 page 等 于 1 时 
$sql = "select min(outshop-inshop).name from tb_demo061 "; /lsql 语句 
Srs = mysql_query($sqD); // 返 回 结 果 集 
Srst = mysql fetch_row($rs); /输出 结果 
> 
<tr><td background="pic/head.JPG"> 利 润 最 小 的 商品 </td><td background="pic/head JPG"><?php echo S$rst[1]:?></td><td 
background="pi ?php echo S$rst[0];?></td><td background="pic/head JPG"></td><td background="pic/head.JPG"></td><td 
background="pic/head. JPG"></td></tr></tal ble></td></tr></tabl 
<?php 
} 
> 
图 秘笈 心 法 


心 法 领悟 405: 聚合 函数 min0 的 主要 应 用 。 
聚集 函数 min0 被 广泛 应 用 于 电子 商务 系统 中 ， 主 要 用 于 商家 在 进货 之 前 计算 自己 商品 的 保底 利润 ， 也 就 是 
最 小 利润 ， 以 防止 因 市 场 价格 变动 而 造成 损失 。 


实例 406 


实例 说 明 


在 商品 销售 管理 系统 中 ， 商 品 的 销售 利润 统计 模块 是 必 不 可 少 的 。 运 行 本 实例 ， 如 图 8.76 所 示 ， 在 图 中 文 
本 框 中 输入 某 月 份 ， 单 击 “ 查 询 ” 按 钮 ， 即 可 将 2005 年 销售 额 最 大 的 商品 信息 显示 出 来 。 


使 用 聚 全 因数 MAX 或 利润 景 高 的 商品 
外 一 
Fa 


而 外 so 神 夺 2005-;2-08 张 

Ta 了 3242  a  2005-i2-l1 他 
308 rH st 让 方 站 声 200512-05 EE 
267 19M 十 关 锋 3000 广场。 2005-12-07 % 
2 I 2 005-Jz-ll 侍 


图 8.76 获取 月 利润 最 大 的 商品 信息 


图 关键 技术 


实现 本 实例 ， 主 要 应 用 到 SQL 语言 中 的 max0 函 数 ， 该 函数 的 语法 格式 如 下 : 

max([all | distinct] expression) 

参数 说 明 : 

all: 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 all 或 distinct， 则 表示 对 指 
定 字 段 的 所 有 记录 进行 聚集 运算 。 

distinct: 表示 对 指定 字段 的 所 有 非 重复 记录 求 最 大 值 。 

expression: 是 精确 数字 或 近似 数字 数据 类 型 (bit 数据 类 型 除外 ) 分 类 的 表达 式 。 


图 设计 过 程 
(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
人 /连接 MySQL 数据库 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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通过 countO 函 数 求 出 表 中 所 有 记录 的 总 和 。 本 实例 将 讲解 SQL 语言 中 countO 函 数 的 应 用 。 运行 本 实例 , 如 图 8.77 
所 示 ， 首 先 在 图 中 的 文本 框 中 输入 某 数值 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 有 利润 大 于 该 数值 的 数据 求 出 。 


图 8.77 取得 大 于 某 值 的 数据 


图 关键 技术 


统计 表 中 满足 一 定 条 件 的 记录 个 数 ， 可 以 通过 SQL 语言 的 count0 函 数 实现 ， 该 函数 的 使 用 格式 如 下 : 
max([all | distinct] expression) 

该 函数 参数 的 详细 说 明 请 详 见 实例 403， 这 里 不 再 袭 述 。 

本 实例 实现 取得 大 于 某 值 的 数据 的 SQL 语句 如 下 : 


Select count(*) as a from tb_demo061 where $ POST[text] < outshop; 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 在 文本 框 中 输入 内 容 时 ， 单 击 “ 查 
询 ” 按 钮 ， 显 示 如 图 8.77 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


if($_POST[sub){ // 单 击 按钮 
这 $_POST[text] !="" || $_POST[text] != "输入 查询 值 "){ 1/ 判断 文本 框 信息 
这 preg_match("d/"S_POST[textD){ /正则 表达 式 验证 信息 
S$rs = mysql_query("select count(*) as a from tb_demo061 where $ POST[text] < outshop"); /返回 结果 集 
Srst= mysql_fetch_row(Srs): /输出 结果 
> 
<table><tr><td width="580px" align="center"> 共 查找 到 <?php echo $rst[0]:?> 条 </td></tr></table> 
<?php 
jelse{ 
echo "<script>alert( 请 正确 输入 '):</script>"; /JavaScript 提示 
jelse{ 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 ):</script>"; //JavaScript 提示 
} 
3 
> 
图 秘笈 心 法 


心 法 领悟 407: 分 析 count0 聚 集 函 数 与 mysql_num rows0 函 数 。 
count0 聚 集 函 数 与 PHP 操作 MySQL 函数 mysql_ num rows0 在 处 理 分 页 显示 时 ， 作 用 完全 相同 ， 但 是 后 者 
能 较 单一 ， 不 够 灵活 。 


高 级 
趣味 指数 : 窗帘 从众 : 


力 实例 说 明 


SQL 语言 中 ， 获 取 表 中 的 第 一 条 记录 或 最 后 一 条 记录 可 以 通过 函数 first0 和 last0 实 现 ， 由 于 Access 数据 库 
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图 中 
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对 这 两 个 函数 的 支持 较为 完善 ， 本 实例 将 采用 Access 作为 后 台数 据 库 。 运 行 本 实例 ， 如 图 8.78 所 示 ， 分 别 单 击 
的 “获取 第 一 条 记录 ”和 “获取 最 后 一 条 记录 ”按钮 即 可 获得 表 中 的 第 一 条 或 最 后 一 条 记录 。 


图 关键 技术 


SQL 语言 中 ， 获 取 表 中 的 第 一 条 记录 或 最 后 一 条 记录 可 以 通过 函数 first0 和 last0 实 现 ， 这 两 个 函数 的 使 用 


语法 如 下 : 


first(expression) 
last(expression) 


expression 代表 一 个 字符 串 表达 式 ， 它 包含 要 使 用 的 数据 字段 ， 或 者 是 使 用 该 数据 字段 参与 执行 的 表达 式 ， 


expression 中 的 操作 可 以 包含 表 的 字段 、 常 量 等 。 


图 设计 过 程 


550 


(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
<?php 


S$conn=new com("adodb.connection"); /实例 化 adodb.connection 
Sconnstr="provider=microsoft.jet.oledb.4.0:data source=" .realpath("./data/db_database07_186.mdb"); 1/ 调用 db_database07_196. 
Sconn->open($connstr); 
> 
(2) 判断 用 户 提交 的 名 称 ， 从 而 确定 显示 第 一 条 记录 还 是 最 后 一 条 记录 ， 代 码 如 下 : 
<?php 
function convert(Stext){ // 自 定义 转 码 函数 


Teturn iconv(‘gbk', ‘utf-8', $text); 


} 
if($_POST[submit1]!="" || $_POST[submit2]!="") { 
include("conn.php"); // 包 含 连 接 数 据 库 文件 
Srs=new com("adodb.recordset"); 1/ 实例 化 对 象 
if($_POST[submit1]!="") { 
S$rs->open("select first(sno) as snol ,first(sname) as sname]l, first(sclass) as sclassl,first(ssubject) as ssubjectl,first(sscore) as sscorel from 
Score",$conn.3,1): 
yelseif($_POST[submit2]!=""){ 
Srs->open("select last(sno) as snol ,last(sname) as snamel., last(sclass) as sclass1.last(ssubject) as ssubjectl,last(sscore) as sscorel from 
score",$conn,3,1); 


} 
seo Srs->boD){ 


<t> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 查找 到 该 学 生成 绩 ! </div></td> 
</tr 
< 
} elsef 


3 

<?php 
while(!S$rs->eof){ 
> 


<t> 

<td width="170" height="20" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sno1")->value)?> 

/div></td> 

<td width="170" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sname1")->value)?> 

Jdiv></td> 

<td width="143" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sclass1")->value)?> 
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</div></td> 

<td width="130" bgcolor—"#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("ssubject1")->value)?> 

</div></td> 

<td width="131" bgcolor—"#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sscore1")->value)?> 

</div></td> 

<> 


<php 
Srs->movenext' 
} 
li 
} 
?> 


力 秘笈 心 法 


心 法 领悟 408: Access 数据 库 一 一 PHP 程序 员 必 修 课程 之 一 。 

Access 数据 库 并 不 是 与 PHP 操作 数据 库 联合 使 用 的 首选 ， 但 是 由 于 各 个 数据 库 之 间 存 在 差异 ， 函 数 支持 程 
度 也 有 强 有 弱 ， 所 以 作为 一 个 优秀 的 PHP 程序 员 ， 不 仅 要 掌握 MySQL 这 一 种 数据 库 ， 还 要 对 Access 数据 库 有 
所 了 解 。 


8.7 多 表 查 询 
在 实际 的 Web 开发 过 程 中 ， 经 常 将 类 别 不 同 的 信息 存储 在 不 同 的 表 中 ， 表 之 间 通 过 特定 的 字段 相互 关联 ， 
所 以 在 任何 一 个 有 规模 的 Web 项 目 中 ， 都 可 以 看 到 多 表 查 询 的 身影 。 本 节 将 通过 几 个 典型 的 实例 讲解 SQL 语 
言 中 多 表 查 询 的 使 用 方法 。 


高 级 | 
趣味 指数 : 耸 耸 人 评 催 | 


力 实例 说 明 


在 实际 项 目 开 发 过 程 中 ， 经 常 需要 将 不 同 的 信息 存储 在 不 同 的 表 中 ， 表 与 表 之 间 通 过 某 字段 相互 关联 ， 从 而 
使 表 的 指针 形成 一 种 连 动 关系 进而 可 以 通过 SQL 语言 的 select 语句 实现 多 表 查 询 。 运 行 本 实例 ， 如 图 8.79 所 示 ， 
在 图 中 文本 框 中 输入 要 查询 成 绩 的 学 生 学 号 ， 单 击 “ 查 找 ” 按钮 ， 即 可 将 学 生 信息 和 该 学 生 的 各 科 成 绩 查找 出 来 。 


om 及 


学 生 1D 学 生 姓 名 ”家庭 住 址 入 学 日 期 。 数学 考试 分 类 的 括 ”语文 考试 分 数 
1 小 槐 。。 刘 长 2-21 91 9 


EE ED 


8.79 多 表 查 询 


图 关键 技术 


SQL 语言 中 ， 通 过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 最 好 用 “表明 .字段 名 ”表示 ， 这 样 可 以 防 
止 因 表 之 间 字 段 重 名 而 造成 无 法 获知 该 字段 属于 哪个 表 。 在 where 子 句 中， 多 个 表 之 间 所 形成 的 连 动 关系 应 按 
如 下 形式 书写 : 

表 1 字段 - 表 2. 字段 and 其 他 查询 条 件 


551 


PHP 开发 实战 1200 例 (第 I 卷 ) 


综 上 所 述 ， 实 现 多 表 查 询 ， 应 按 如 下 形式 : 
select 字段 名 from 表 1. 表 2…where 表 1. 字 段 = 表 2. 字 段 and 其 他 查询 条 件 


图 设计 过 程 

编写 index.php 文件 ， 当 用 户 在 文本 框 中 输入 数据 并 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.79 所 示 的 内 容 ， 核 
心 代 码 如 下 : 

<?php 

Sconn = mysql_connect("localhost"."root","111") or die ("Connect MySQL false"): // 连 接 MySQL 

mysql_select_db("db_database08", Sconn); // 连 接 数 据 库 

mysql_query("SET NAMES UTF8"); // 设 置 编码 格式 

if($_POST[sub){ // 当 单 击 按钮 时 


/返回 结果 集 。 
Srs= mysql_query("select a.id.a.name.a.address,a.date.b.math.b.english.b.chinese from tb_demo065 tel as b.tb_demo065 as a where a.id=b.id 
Er POST[text]"); 


2 width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td 
background="pic/head.JPG"> 家 庭 住址 </td><td background="pic/head.JPG"> 入 学 日 期 </td><td background="pic/head.JPG"> 数 学 考试 分 数 </td><td 
background="pic/head.JPG"> 英 语 考试 分 数 </td><td background="pic/head.JPG"> 语 文 考试 分 数 </td></tr> 


hp 
while($rst = mysql_fetch_row($rs){ /循环 输出 结果 


> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1]: ed 
background="pic/head.JPG"><?php echo S$rst[21];?></td><td background="pic/head.JPG"><?php echo $rst[31:?></td><t 
background="pic/head.JPG"><?php echo S$rst[4];?></td><td background="pic/head.JPG"><?php echo S$rst[5]: a 
ee "pic/head.JPG"><?php echo $rst[6]:?></td></tr> 
< 

} 
} 
> 


图 秘笈 心 法 


心 法 领悟 409: 设置 两 表 关联 的 注意 事项 。 
本 实例 在 where 子 名 上， 以 两 张 表 的 过 字段 信息 相同 作为 条 件 建立 两 表 关联 。 笔 者 意 在 显示 实例 原理 ， 在 


实际 开发 中 不 建议 这 样 使 用 ， 最 好 使 用 主 外 键 约束 来 实现 。 


趣味 指数 : 谷 耸 评语 | 


图 实例 说 明 


为 了 提高 SQL 语句 的 可 读 性 ,经常 采 取 为 表 取 别 名 的 方式 对 表 进 行 查 询 。 运行 本 实例 ， 如 图 8.80 所 示 ， 首 
先 在 图 中 文本 框 中 输入 要 查询 的 学 生成 绩 的 学 号 ,然后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 该 学 生 的 学 生成 绩 查找 出 来 。 


图 8.80 ”使 用 表 的 别名 


图 关键 技术 


SQL 语言 中 ， 可 以 通过 两 种 方式 为 表 指定 别名 ， 第 一 种 是 通过 关键 字 as 指定 ， 例 如 : 
select 字段 名 from 表 名 as 表 的 别名 where 条 件 .… 
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第 二 种 是 在 表 名 后 直接 加 表 的 别名 从 而 为 表 指 定 别名 ， 例 如 : 


select 字段 名 from 表 名 表 的 别名 where 条 件 … 
本 实例 将 利用 表 的 别名 实现 多 表 查 询 ， 代 码 如 下 : 


select a.id.a.name.a.address.a.date.b.math.b.english.b.chinese from tb demo065 tel asb ,tb_ demo065 as a where a.id=b.id and aid-$ POST[text] 
图 设计 过 程 

创建 网 页 文件 index.php。 编 写 网 页 框架 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 在 文本 框 中 输入 信 
息 ， 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.80 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


Sconn = mysql_connect("localhost","root","111") or die ("Connect MySQL false"); /连接 MySQL 
mysql_select_db("db_database08",$conn); /连接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"); // 设 置 编码 格式 
if($_POST[sub){ / 单 击 按钮 

Srs = mysql_query("select a.id.a.name.a.address,a.date.b.math,b.english.b.chinese from tb_demo065 tel asb .tb_demo065 as a where aid=b.id 
Ee POST[text]"): // 返 回 结果 集 


2 width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 家 庭 住 址 </td><td background="pic/head.JPG"> 入 学 日 期 </td><td background="pic/head.JPG"> 数 学 考试 分 数 </td><td 
background="pic/head.JPG"> 英 语 考试 分 数 </td><td background="pic/head.JPG"> 语 文 考试 分 数 </td></tr> 


hp 

while($rst = mysql fetch row(Srs){ /循环 输出 结果 
<tr><td background="pic/head. JPG"><?php echo Srstf0]:?></td><td background="pic/head.JPG"><?php echo Srst[11:2></td><td 
background="pic/head. JPG"><?php echo S$rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:?></td><td 


background="pic/head.JPG"><?php echo $rst[4];?></td><td background="pic/head. JPG"><?php echo $rst[5]:?></td><td 
ee echo Srst[61:?></td></tr> 


| 


图 秘笈 心 法 


心 法 领悟 410: 使 用 表 的 别名 。 
在 使 用 表 的 别名 时 应 注意 以 下 两 点 : 
(1) 别名 通常 是 一 个 缩短 了 的 表 名 ,用 于 在 连接 中 引用 表 中 的 特定 列 ， 如 果 连 接 中 的 多 个 表 中 有 相同 的 名 
称 列 存在 ， 必 须 使 用 表 名 或 表 的 别名 限定 列 名 。 
(2) 如 果 定 义 了 表 的 别名 就 不 能 再 使 用 表 名 。 
i 让 
人 人 


力 实例 说 明 


SQL 语言 中 ， 使 用 关键 字 union 可 以 将 多 张 表 的 信息 合并 输出 。 如 图 8.81 所 示 为 数据 库 中 无 关联 的 两 张 员 
工 信 息 表 ， 运 行 本 实例 ， 单 击 “ 合 并 ”按钮 ， 即 可 将 这 两 张 表 的 信息 合并 输出 ， 如 图 8.82 所 示 。 


uid name price date i name pwd 

FX +1 8 15100 20100724 FF 用 X 1 4 1081 

A EE sm mmr F HX 14 0 

Fr HX 3 28kN mm momra F FX 3 + 105 

FX 4 a 00 Zo 六 X44 107 
图 8.81 两 张 无 关 联 表 8.82 ”合并 多 个 结果 集 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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力 关键 技术 
多 表 之 间 的 嵌 套 查询 可 以 通过 谓词 in 实现 ， 该 谓词 的 语法 格式 如 下 : 


test_expression[not] in{ 
subquery 


} 

参数 说 明 : 

test_expression: 指 SQL 表达 式 。 

subquery: 包含 某 列 结果 集 的 子 查 询 ， 该 列 必须 与 test_expression 具有 相同 的 数据 类 型 。 


图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.84 
所 示 的 内 容 ， 代 码 如 下 : 

php 


$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"”); // 连 接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"); /设置 编码 
ifS_POST[sub]){ /设置 编码 格式 
$sql = "select * from tb_demo069_ people where uid in (select deptID from tb_demo069_dept where deptName ='$_POST[text])"; /sql 语 名 
Srs = mysql_query($sql); // 返 回 结果 集 


全 width="580px"><tr><td background="pic/head.JPG"> 员 工 编号 </td><td ee 
Eee 只 工 姓名 </td><td background="pic/head.JPG"> 性 别 </td></tr 


pe while(Srst = mysql_fetch_row($rs){ /循环 输出 
二 background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1]:?></td><td 
Bebo ete POSS echo Srst[21;2></td><td background="pic/head.JPG"><?php echo $rst[3]:?></td></tr> 
<?pl 

} 
} 
Wn 
秘笈 心 法 
心 法 领悟 413: 多 表 嵌 套 查询 的 原理 。 
对 于 数据 表 的 嵌 套 查询 ， 用 户 一 定 要 掌握 其 查询 原理 ， 即 无 论 是 多 少 张 表 进行 嵌 套 ， 表 与 表 之 问 一 定 存在 
某 种 关联 ， 通 过 where 子 句 建立 此 种 关联 实现 查询 。 


趣味 指数 : 耸 侠 侠 催 | 


力 实例 说 明 


嵌 套 查询 在 实际 项 目 开 发 过 程 中 应 用 较 频 繁 ， 可 以 通过 一 条 SQL 语句 实现 多 表 之 间 的 复杂 查询 。 本 实例 将 
利用 婴 套 查询 实现 查询 部 门 员 工 与 公司 部 门 的 详细 信息 。 运 行 本 实例 ， 如 图 8.85 所 示 。 


8.85 查询 统计 应 用 
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图 关键 技术 


实现 多 表 的 嵌 套 查询 时 ， 可 以 同时 使 用 谓词 any、some 和 all， 这 些 谓词 被 称 为 定量 比较 谓词 ， 可 以 和 比较 


运算 符 联 合 使 用 ， 判 断 是 否 全 部 返回 值 都 满足 搜索 条 件 。some 和 any 谓词 是 存在 量 的 ， 只 注重 是 否 有 返回 


值 


满足 搜索 要 求 ， 这 两 个 谓词 的 含义 相同 ， 可 以 替换 使 用 ， all 谓词 称 为 通用 谓词 ， 它 只 关心 是 否 有 谓词 满足 搜索 


any | some |all 谓词 的 语法 形式 如 下 : 
scalar_expression {查询 条 件 运算 符 }{ some | any }(subquery) 
参数 说 明 : 

scalar_ expression: 指 任何 有 效 的 SQL 表达 式 
subquery: 指 包含 某 列 结果 集 的 子 查 询 。 


本 实例 实现 查询 统计 的 SQL 语句 的 代码 如 下 : 
select * from tb_demo069_people where uid in (select deptID from tb_demo069_dept where deptName ='$_POST[select]’; 


图 设计 过 程 
创建 脚本 文件 ndex.php， 编 写 下 拉 列 表 框 。 选 择 部 门 ， 当 单 击 “ 查 询 ” 按钮 时 ， 显 示 如 图 8.85 所 示 的 内 容 ， 
代码 如 下 : 
<?php 
Sconn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"); /连接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"); /设置 编码 格式 
这 $_POST[sub]){ /| 单 击 按钮 
if($_POST[select] — "1"){ V 下 拉 列 表 设置 
echo "<script>alert(' 请 选择 部 门 );</script>"; /Javascript 设置 
Jelse{ 
/sql 语 句 
$sql = "select + from tb demo069 people where uid in (select deptID from tb demo069 dept where deptName = '$ POST[selectl)": 
S$rs = mysql_query($sqD); /1/ 返 回 结 果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 员 工 编号 </td><td background="pic/head.JPG"> 部 门 名 称 </td><td 
background="pic/head.JPG"> 员 工 姓名 </td><td background="pic/head.JPG"> 性 别 </td></tr> 
<2php 
while(Srst = mysql_fetch row(Srs){ /循环 输出 结果 
> 


<tr><td background="pic/head. JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"><?php echo $_POST[select]:?></td><td 
background="pic/head.JPG"><?php echo Srst[2]:?></td><td background="pic/head. JPG"><?php echo Srst[3]:2></td></tr> 
<?php 

于 


图 秘笈 心 法 
心 法 领悟 414: 堪 套 查询 的 广泛 应 用 。 
利用 谓词 all 查询 所 有 员工 工资 在 3000 元 以 上 的 员工 信息 。 
利用 谓词 any 查询 由 人 民 邮 电 出 版 社 出 版 的 图 书 名 称 。 
SI expression { 夺 询 条 件 运算 符 }{ some | any Canbquer 
参数 说 明 : 
scalar_expression: 指 任何 有 效 的 SQL 表达 式 
subquery: 指 包含 某 列 结果 集 的 子 查询 
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SQL 语言 中 ， 应 用 子 查询 应 遵循 以 下 规则 : 
(1) 由 比较 运算 符 引 入 的 内 层 子 查询 只 包含 一 个 表达 式 或 列 名 ,在 外 层 语 句 中 的 where 子 句 内 命名 的 列 必 
须 与 内 层 子 查询 命名 的 列 兼容 。 
(2) 由 不 可 更 改 的 比较 运算 符 引 入 的 子 查询 (比较 运算 符 后 面 不 跟 关 键 字 any 或 all) 不 包括 group by 或 


having 子 句 ， 除 非 预 先 确 定 了 成 组 或 单个 的 值 。 
(3) 用 exists 引入 的 select 列表 一 般 都 由 * 组 成 ， 不 必 指 定 列 名 。 
(4) 子 查询 不 能 在 内 部 处 理 其 结果 。 


高 级 | 
起 味 指数: 请 守 请 育 


图 实例 说 明 
本 实例 通过 计算 各 科 平 均 成 绩 作为 子 查询 表达 式 的 方式 来 取得 学 生 的 各 科 平 均 成 绩 。 运 行 本 实例 , 如 图 8.88 
所 示 ， 单 击 图 中 的 “显示 平均 成 绩 ” 按 钮 ， 即 可 将 该 班级 学 生 的 所 有 学 科 的 平均 成 绩 显 示 在 图 中 最 后 一 行 。 


因 
EU 


图 8.88 使 用 子 查询 作 派生 的 表 


本 实例 中 ， 求 得 学 生 各 科 平 均 成 绩 的 代码 如 下 : 
select (select avg(chinese) from tb_demo071).(select avg(math) from tb_demo071).(select avg(english) from tb_demo071) from tb_demo071: 
其 中 ，select avg(chinese) from tb_demo071、select avg(math) from tb_demo071 和 select avg(english) from 


tb_demo071 为 该 SQL 语句 的 子 查询 ， 分 别 用 于 获得 该 班级 学 生 的 语文 、 数 学 和 英语 的 平均 成 绩 。 
力 设计 过 程 

创建 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 文件 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 
击 “ 显 示 平 均 成 绩 ” 按 钮 时 ， 显 示 如 图 8.88 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


这 $_GET[id] = "1"){ /如 果 地 址 栏 记 等 于 1 
/sql 语 句 
S$sql = "select (select avg(chinese) from tb_demo071).(select avg(math) from tb_demo071).(select avg(english) from tb_demo071) from 
tb demo071"; 
Srsss = mysql_query($sq]) or die ("false"”); /返回 结果 集 


Srsst = mysql_fetch_array($rsss): 
<tr><td background="pic/head.JPG"> 各 科 平 均 成 绩 </td><td background="pic/head.JPG"></td><td background="pic/head.JPG"></td><td 
background—"pic/head JPG"></td><td background="pic/head. JPG"><?php echo Srsst[0]:?></td><td background="pic/head. JPG"><?php echo 
Srsst[1]:2></td><td background="pic/head.JPG"><?php echo S$rsst[2]:?></td></tr> 
<?php 


> 


> 
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图 秘笈 心 法 


心 法 领悟 416: 方便 的 别名 。 
在 使 用 子 查询 时 最 好 为 列表 项 取 个 别名 ， 这 样 可 以 方便 用 户 在 使 用 mysql_fetch_arrayO 函 数 时 为 表 项 赋值 。 


实例 417 


力 实例 说 明 


使 用 子 查询 关联 数据 在 实际 项 目 开发 过 程 中 被 广泛 应 用 ， 它 可 以 使 多 表 之 间 的 查询 变 得 更 加 简捷 。 运 行 本 
实例 ， 如 图 8.89 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查询 的 班级 名 称 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 该 班级 
所 有 学 生 的 详细 信息 查询 出 来 。 


图 8.89 使 用 子 查询 关联 数据 


图 关键 技术 

本 实例 实现 使 用 子 查询 关联 数据 的 SQL 语句 的 代码 如 下 : 

select * from tb_demo072_student where uid = (select id from tb_demo072_class where className ='$_POST[text] );: 
图 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 编 写 文本 框 ， 为 文本 框 设置 初始 值 ， 
当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.89 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
ifS_POST[sub]){ // 单 击 按钮 
Srs= mysql_query("select * from tb_demo072_student where uid = (select id from tb_demo072_class where className ='$_POST[text] )"); 
/返回 结果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 学 生性 别 </td><td background="pic/head.JPG"> 语 文成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td 
background="pic/head.JPG"> 英 语 成 绩 </td></tr> 


hp 
while($rst = mysql_fetch_row($rs){ /循环 输出 结果 
ea 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[2]:?></td><td 
background="pic/head. JPG"><?php echo Srst[3]:?></td><td background="pic/head JPG"><?php echo Srst[4]:?></td><td 
background="pic/head JPG"><?php echo S$rst[51:2></td><td background="pic/head JPG"><?php echo S$rst[61:?></td><td 
background="pic/head.JPG"><?php echo $rst[7]:?></td></tr> 


} 
> 


秘笈 心 法 
心 法 领悟 人 17: 浅 谈 本 实例 的 实现 原理 。 
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本 实例 的 实现 原理 是 通过 内 查询 select id from tb_demo072 class where className = '$_ POST[text] 获 取 要 查 
询 的 班级 名 称 ， 然 后 通过 外 部 查询 获取 要 查询 的 班级 的 所 有 学 生 的 详细 信息 。 


图 实例 说 明 


多 表 联 合 查 询 可 以 解决 连接 或 简单 子 查询 难于 处 理 的 问题 。 运 行 本 实例 ， 如 图 8.90 所 示 ， 单 击 图 中 的 “ 合 
并 学 生 信息 ”按钮 ， 即 可 将 计算 机 系 和 数学 系 的 学 生 信息 合并 输出 。 


多 氏 联 入 要 询 | 


二 开学 生 信 息 


了 徊 2010-07-26 
未 到 O00 
小 滞 2010-06-19 
2010-06-18 
小 到 2010-07-26 
小 新 2010-07-17 


图 8.90 多 表 联 合 查询 


站 


图 关键 技术 

利用 SQL 语言 中 的 关键 字 union， 可 以 将 不 同 表 中 符合 条 件 的 数据 信息 显示 在 同一 列 中 。union 语句 的 使 用 
格式 如 下 : 

<query specification1> [,query specification2……] union [all] <query specification1> [,query specification2……] 

参数 说 明 : 


<query specification1>: 是 查询 规范 或 查询 表达 式 。 
union: 组 合 多 个 结果 集 并 将 其 作为 单个 结果 集 返 回 。 
1: 在 结果 集中 包含 所 有 的 行 ， 包 含 重 复 行 。 

图 ee 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “合并 学 生 信息 ”按钮 时 ， 显 
示 如 图 8.90 所 示 的 内 容 ， 核 心 代码 如 下 : 

/如果 地 址 栏 过 等 于 1 

/返回 结果 集 
Srs = mysql_query("select * from tb_demo074_student union select * from tb_demo074_fasten"); 


<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 入 学 时 间 </td></tr> 


while($rst = mysql_fetch_row(Srs)){ /1/ 循 环 输出 结果 


2 
<tr><td background="pic/head.JPG"><?php echo $rst[01:?></td><td background="pic/head.JPG"><?php echo Srst[11?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td></tr> 


} 


} 
> 


561 
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图 秘笈 心 法 


心 法 领悟 418: 使 用 union 关键 字 的 注意 事项 。 

在 使 用 关键 字 union 时 应 注意 以 下 两 点 : 

(1) 在 使 用 union 运算 符 组 合 的 语句 中 ， 所 有 选择 列表 的 表达 式 数 目 必须 相同 ， 如 列 名 、 算 术 表 达 式 及 聚 
合 函数 等 。 

(2) 在 每 个 查询 表 中 ， 对 应 列 的 数据 必须 是 同一 数据 类 型 。 


高 级 
起 味 指数 :请 二 请 育 


图 实例 说 明 


为 了 与 union 运算 兼容 ， 要 求 所 有 select 语句 都 不 能 有 order by 子 句 ,但 有 一 种 情况 例外 ， 那 就 是 在 最 后 一 
个 select 语句 中 放置 order by 子 句 实现 结果 的 最 终 排 序 输出 。 运 行 本 实例 ， 如 图 8.91 所 示 ， 单 击 图 中 的 “合并 
学 生 信息 ”按钮 ， 即 可 将 所 有 的 学 生 信息 合并 ， 并 按 入 学 时 间 降 序 输出 。 


属 开 学 生 信和 | 


2010-07-24 
FIET 
2010-07-20 
3010-07-17 
2010-06-19 
2010-06-18 


图 8.91 对 联合 查询 结果 进行 排序 


图 关键 技术 


本 实例 实现 对 联合 查询 结果 进行 排序 的 SQL 语句 的 代码 如 下 : 

select * from tb_demo074_student union select * from tb_demo074_fasten order by date desc: 
图 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 合 并 学 生 信息 ”按钮 时 ， 显 
示 如 图 8.91 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 

这 $_GET[id] —"1"){ // 如 果 地址 栏 参数 这 等 于 1. 


/返回 结果 集 
Srs = mysql_query("select * from tb_demo074_student union select * from tb_demo074_fasten order by date desc"); 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 入 学 时 间 </td></tr> 


while($rst = mysql fetch_row($rs){ /循环 输出 结果 


> 
<tr><td background—"pic/head JPG"><?php echo $rst[01:?></td><td background—"pic/head. JPG"><?php echo Srst[11:2></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td></tr> 


b 
} 


> 
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图 秘笈 心 法 
心 法 领悟 419: 使 用 union 关键 字 的 注意 事项 。 
union 语句 在 使 用 条 件 上 相对 比较 苛刻 ， 所 以 在 使 用 此 语句 时 一 定 要 注意 两 个 表 项 数目 或 字段 类 型 是 否 相同 。 
高 级 
趣味 指数 : baledoioll 


图 实例 说 明 

本 实例 将 应 用 group by 分 组 语句 和 having 语句 实现 条 件 联合 查询 。 运 行 本 实例 ， 如 图 8.92 所 示 ， 单 击 图 
中 的 “出 版 社 信息 ”按钮 ， 即 可 将 全 国 各 个 大 型 出 版 社 的 名 单 显示 出 来 ， 并 保证 人 民 邮 电 出 版 社 和 机 械 工 业 出 
版 社 始终 位 于 名 单 最 前 列 。 


有 -iT 和 和 


人 民 邮 电 出 贱 社 


机 械 工 业 出 版 社 
东北 财经 大 党 出 版 社 
清华 大 学 出 同 社 


图 8.92 条 件 联合 语句 


图 关键 技术 


本 实例 的 条 件 联 合 语句 中 , 首先 按 出 版 社 名 称 (name) 进行 分 组 , 然后 利用 having 子 句 限定 条 件 , 如 having 
name= 人 民 邮 电 出 版 社 'or name= 机 械 工业 出 版 社 '， 这样， 执行 结果 将 显示 出 人 民 邮 电 出 版 社 和 机 械 工 业 出 版 社 
这 两 条 记录 ， 最 后 用 union all 运算 符 与 另 一 个 数据 表 合并 ， 并 利用 having 限定 条 件 having name<>' 人 民 邮 电 
出 版 社 ' and name<>' 机 械 工业 出 版 社 ') ， 即 可 调 出 全 国 各 大 型 出 版 社 的 名 称 ， 并 且 确保 人 民 邮 电 出 版 社 和 机 械 
工业 出 版 社 始终 位 于 名 单 最 前 列 。 本 实例 中 实现 联合 查询 的 代码 如 下 : 


select name from tb_demo076_Beijing group by name having name=' 人 民 邮 电 出 版 社 ' or name= 机 械 工业 出 版 社 ' union all select name from 
也 _demo076_Beijing group by name having name<>' 人 民 邮 电 出 版 社 'and name<>' 机 械 工业 出 版 社 ' 


图 设计 过 程 

编写 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 出 版 社 信息 ”按钮 时 ， 显 示 如 
图 8.92 所 示 的 内 容 。 本 实例 的 核心 代码 如 下 : 

一 "19f /y/ 单 击 按钮 


S$rs = mysql_query("select name from tb_demo076_Beijing group by name having name=' 人 民 邮 电 出 版 社 'or name=' 机 械 工业 出 版 社 'union all 
select name from tb_demo076_Beijing group by name having name<>' 人 民 邮 电 出 版 社 ' and name<>' 机 械 工 业 出 版 社 "): /返回 结果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 出 版 社 信息 </td></tr> 
while($rst = mysql_fetch row(Srs)){ /1/ 循 环 输出 结果 


2 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[0]:?></td></tr> 
<?php 

> 


> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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力 秘笈 心 法 


心 法 领情 421: 多 表 查 询 实现 的 方法 。 
本 实例 使 用 的 内 连接 只 是 SQL 语句 的 一 种 方法 ， 此 方法 可 以 使 用 多 表 查 询 的 知识 实现 相同 功能 。 使 用 多 表 


查询 的 SQL 语句 的 代码 如 下 : 
select a.name,a.address,a.date,b.math.b.english.b.chinese from tb_demo065 as a.tb_demo065 tel as b where aiid=b.id; 


高 级 | 
趣味 指数 : hohohof| 


力 实例 说 明 


在 实际 项 目 开 发 过 程 中 ， 所 应 用 的 内 连接 查询 大 多 都 是 较 复杂 的 ， 例 如 对 多 张 表 通过 内 连接 方式 建立 关联 
后 , 还 需要 在 SQL 语句 中 再 指明 一 些 查询 条 件 ， 从 而 进一步 实现 查询 的 精确 定位 。 运行 本 实例 , 如 图 8.94 所 示 ， 
首先 在 图 中 的 文本 框 中 输入 要 查询 的 员工 编号 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 要 查询 的 员工 的 基本 信息 和 
工资 状况 查询 出 来 。 


ED 


入 职 时 间 
2010-07-26 


图 8.94 复杂 的 内 连接 查询 


复杂 的 内 连接 查询 是 在 基本 内 连接 查询 的 基础 上 再 附加 一 些 查询 条 件 ， 例 如 本 实例 中 实现 查询 员工 基本 信 
息 情 况 的 代码 如 下 : 

select tb demo078 wages.Wages,tb demo078 informaction .name.tb demo078 informaction.sex.tb demo078 informaction.date from 

tb_demo078_wages inner join tb_demo078_informaction on tb_demo078_wages.id=tb_demo078_informaction.id where 

tb_demo078_informaction.id=(select id from tb_demo078 id where code='$_POST[text]); 


图 设计 过 程 


创建 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 编 写 <form> 表 单 ， 当 单 击 “ 查 询 ” 按 
钮 时 ， 显 示 如 图 8.94 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
if($_POST[sub){ // 单 击 按钮 

Srs = mysql_query("select tb_demo078_wages.Wages.tb_demo078_informaction.name.tb_demo078_informaction.sex.tb_demo078_informaction 
.date from tb_demo078_wages inner join tb_demo078_informaction on tb_demo078 wages.id=tb_demo078 informaction.id where tb_demo078_ 
informaction.id=(select id from tb_demo078_id where code='$_POST[text])"): // 返 回 结果 集 
> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 


while($rst = mysql fetch row(Srs)){ /循环 输出 结果 


ne align="center"><?php echo Srst[1]:?></td><td background="pic/head.JPG” align="center"><?php echo 
Srst[21:7?></td><td background="pic/head.JPG" align="center"><?php echo $rst[31:?></td><td background="pic/head.JPG" align="center"><?php echo 
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} 


> 


图 秘笈 心 法 

心 法 领悟 422: 如 何 选择 SQL 语句 查询 的 方法 。 

实现 复杂 SQL 语句 查询 的 方法 有 很 多 ， 而 且 彼 此 实现 的 功能 相同 ， 至 于 选择 哪 种 方法 ， 则 由 用 户 或 程序 员 
的 个 人 喜好 决定 。 


实例 423 


力 实例 说 明 

建立 表 与 表 之 间 的 关联 是 PHP 程序 员 在 设计 数据 库 时 都 会 遇 到 的 问题 ， 而 两 表 之 间 的 关联 在 中 小 型 网 站 中 
出 现 的 频率 是 最 高 的 。 运 行 本 实例 ， 在 图 8.95 所 示 界 面 的 文本 框 中 输入 员工 工资 ， 单 击 “ 查 询 ” 按 钮 ， 即 可 显 
示 与 文本 框 关联 的 所 有 内 容 。 


[sm] 


图 8.95 两 表 的 内 连接 关联 


图 关键 技术 


本 实例 实现 两 表 关联 的 SQL 语句 的 代码 如 下 : 

select tb demo078 wages.Wages,tb demo078 informaction.name,tb demo078 informaction.sex.tb demo078 informaction.date from tb demo078 
Wages inner join tb_demo078_informaction on tb_demo078_wages.id=tb_demo078_informaction.id where tb_demo078_informaction.id=(select id from 
tb_demo078 id where code='$_POST[text]); 


| | 设计 过 程 


编写 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.95 


所 示 的 内 容 ， 核 心 代码 如 下 : 

这 $_POST[sub]){ / 单 击 按钮 

S$rs= mysql_query("select tb_demo078_wages.Wages.tb_demo078_informaction.name,tb_demo078_informaction.sex,tb_demo078_informaction 
.date from tb demo078 wages inner join tb demo078 informaction on tb demo078 wages.id=tb demo078 informaction.id where tb demo078 
informaction.id=(select id from tb_demo078_id where code='$_POST[text])"): /返回 结果 集 
> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 
<?php 

while(Srst = mysql fetch row($rs){ /| 循环 输出 结果 
> 
<tr><td background="pic/head JPG" align="center"><?php echo S$rst[11:2></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head. JPG" align="center"><?php echo Srst[3]:?></td><td background-"pic/head.JPG" align="center"><?php echo 
Srst[0]:2></td></tr> 
<?php 

} 
} 


> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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left outer join 表示 建立 表 tb yg 和 tb_yg_info 的 外 连接 。 


高 级 | 


实 们 
实例 425 趣味 指数 : 会 会 依依 


图 实例 说 明 

如 果 要 包含 连接 的 两 个 表 中 的 不 匹配 行 ， 可 以 通过 左 连接 或 右 连接 的 方式 实现 。 运 行 本 实例 ， 如 图 8.97 所 
示 ， 单 击 图 中 的 “查询 ”按钮 ， 即 可 将 员工 信息 表 中 的 所 有 记录 以 及 员工 工资 表 中 与 员工 ID 相 匹 配 的 记录 显示 
出 来 。 


和 查询 
2300 \ 小 扬 2010-07-16 
ED 1 不 大 2010-07-16 
3000 3 小 刘 200-07-26 


图 8.97 left outer join 查询 


图 关键 技术 
:连接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 查询 条 件 及 右 表 中 所 有 满足 连接 条 件 的 行 , MySQL 数据 库 中 


左 


使 用 左 连接 的 语法 格式 如 下 : 


select field 1[field2…] from tablel left [outer] join table2 on join_condition [where search_condition] 
参数 说 明 : 

left outer join: 表示 表 之 间 通 过 左 连接 方式 相互 连接 ， 也 可 以 简写 成 left join。 
on join_condition: 指 多 表 建 立 连接 所 使 用 的 连接 条 件 。 

where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 


设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.97 
所 示 的 内 容 ， 核 心 代码 如 下 : 


if($_GET[id] —"1"){ // 单 击 按钮 
S$rs= mysql query("select + from tb demo078 informaction left outer join tb demo078 wages on tb demo078 wages.id= 
tb_demo078_informaction.id "); /返回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 
<?php 
while(Srst= mysql fetch row(Srs)){ /循环 输出 结果 


和 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[1]:?></td><td background="pic/head JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head. JPG" align="center"><?php echo $rst[3]:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[5]:?></td></tr> 
<3php 
} 
} 
> 


力 秘笈 心 法 


心 法 领悟 425: 对 左 连接 的 理解 。 
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左 连 接 以 left outer join 左 侧 的 表 名 为 基准 ， 故 称 左 连接 ， 左 侧 表 名 的 所 有 信息 将 被 全 部 输出 ， 符 合 条 件 的 
右 侧 表 信息 也 会 被 输出 ， 如 果 不 符合 条 件 ， 返 回 NULL。 


实例 说 明 

通过 右 连接 可 以 将 右 表 中 满足 查询 条 件 的 记录 全 部 显示 出 来 ， 并 显示 左 表 中 满足 连接 条 件 的 记录 。 运 行 本 
实例 ， 如 图 8.98 所 示 ， 单 击 图 中 的 “查询 ”按钮 ， 即 可 将 员工 信息 表 中 满足 连接 条 件 的 记录 及 员工 工资 表 中 所 
有 记录 全 部 显示 出 来 。 


2010-07-25 
ER 
Ea 


图 8.98 right outer join 查询 


图 关键 技术 

右 连 接 返 回 的 查询 结果 包含 左 表 中 的 所 有 符合 连接 条 件 以 及 右 表 中 所 有 满足 查询 条 件 的 行 , MySQL 数据 库 
中 使 用 右 连 接 的 语法 格式 如 下 : 

select field 1[field2…] from tablel right [outer] join table2 on join_condition [where search_condition] 

参数 说 明 : 

right outer join: 表示 表 之 间 通 过 右 连接 方式 相互 连接 ， 也 可 以 简写 成 right join。 

on join_condition: 指 多 表 建 立 连接 所 使 用 的 连接 条 件 。 

Where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 


力 设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “查询 ”按钮 时 ， 显 示 如 图 8.98 
所 示 的 内 容 。 本 实例 的 核心 代码 如 下 : 


这 $_GET[idj 一 ”17){ /| 单 击 按钮 

S$rs = mysql query("select + from tb demo078 wages right outer join tb demo078 informaction on tb demo078 wages.id=tb demo078 
informaction id "); /返回 结果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></t1> 


while(Srst = mysql fetch row($rs){ /| 循环 输出 结果 


> 
<tr><td background="pic/head. JPG" align="center"><?php echo $rst[3]:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[4]:?></td><td background="pic/head.JPG" align="center"><?php echo Srst[5]:?></td><td background="pic/head.JPG" align="center"><?php echo 
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图 秘笈 心 法 


心 法 领悟 426: 对 右 连接 的 理解 。 
右 连 接 以 right outer join 右 侧 的 表 名 为 基准 ， 故 称 右 连接 ， 右 侧 表 名 的 所 有 信息 将 被 全 部 输出 ,符合 条 件 的 
左 侧 表 信息 也 会 被 输出 ， 如 果 不 符合 条 件 ， 返 回 NULL. 


图 实例 说 明 
利用 关键 字 in 或 notin 可 以 限定 查询 范围 ， 运 行 本 实例 ， 如 图 8.99 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查 
询 学 生成 绩 的 学 号 范围 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 该 范围 内 的 所 有 学 生 的 各 科 成 绩 查找 出 来 。 


利用 In 或 notin 语 包 展 定 拖 


请 输入 学 号 范围 ;[ 


图 8.99 利用 in 语句 限定 范围 


图 关键 技术 
本 实例 中 ， 利 用 关键 字 ih 查询 指定 学 号 范围 内 的 学 生成 绩 的 代码 如 下 : 


select * from tb_demo083 where code in (select code from tb_demo083 where code between '$_POST[te]' and '$_POST[tex]); 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 编 写 <form> 表 单 ， 当 单 击 “ 查 询 ” 按 
钮 时 ， 显 示 如 图 8.99 所 示 的 内 容 。 核 心 代码 如 下 : 


if($_POST[sub) { // 单 击 按钮 

S$rs = mysql_query("select + from tb_demo083 where code in (select code from tb_demo083 where code between '$_POST[te] and 
'$_POST[tex])"): /返回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 学 生 编 号 </td><td background="pic/head.JPG" align="center"> 学 生 姓名 
</td><td background="pic/head.JPG" align="center"> 语 文成 绩 </td><td background="pic/head.JPG" align="center"> 数 学 成 绩 </td><td 
background="pic/head.JPG" align="center"> 英 语 成 绩 </td></tr> 

<php 


while($rst = mysql_fetch_row($rs)){ // 循 环 输出 结果 
En 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[1]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[2]:2></td><td background="pic/head.JPG" align="center"><?php echo Srst[3]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[41:?></td><td background="pic/head. JPG" align="center"><?php echo S$rst[51:2></td></tr> 
<?php 


} 
B 
> 


图 秘笈 心 法 
心 法 领悟 427: 如 何 书 写 不 在 指定 范围 的 SQL 语句 代码 。 
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在 本 实例 的 SQL 语句 代码 中 ， 如 果 想 查找 不 在 指定 范围 内 的 所 有 信息 ， 可 以 将 让 改 为 notin。 


图 实例 说 明 


SQL 语言 中 ， 可 以 利用 关键 字 加 来 查询 表 中 满足 一 定 条 件 的 记录 。 运 行 本 实例 ， 如 图 8.100 所 示 ， 首 先 在 
图 中 的 文本 框 中 输入 要 查询 的 图 书 名 称 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 与 用 户 输入 的 查询 关键 字 相 匹配 的 图 


书 查找 出 来 。 
用 INR OE ON 
PN 
[EE ED 
图书 蝙 号 图 书 名 各 出 版 社 图 书 作者 
加 不 ASP, RET 编程 字 实 》 | 机 械 工 业 出 版 社 明日 科技 
《PRP 范例 实 戌 字 实 》 请 年 天 学 出版 社 明日 科技 
图 8.100 用 in 查询 表 中 记录 
图 关键 技术 


本 实例 首先 通过 in 子 查询 查找 出 所 有 与 用 户 输入 的 关键 字 相 匹配 的 图 书 名 称 ， 然 后 通过 外 部 查询 查找 出 所 
有 图 书 的 详细 信息 ， 代 码 如 下 : 

select * from tb_demo084 where name in (select name from tb_demo084 where name like '%6$_POST[te]o6'; 
图 设计 过 程 

创建 脚本 文件 index.php。 编 写 网 页 框架 ， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 编 写 <form> 表 单 ， 当 
单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.100 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
if($_POST[sub) { // 单 击 按钮 
这 $_POST[te] 一 “||$_POST[te] 一 "输入 关键 字 "){ /对 文本 框 信息 进行 判断 
echo "<script>alert( 请 输入 内 容 );</script>"; /JavaScript 提示 
Jelse{ 
$sql = "select * from tb_demo084 where name in (select name from tb_demo084 where name like 9%6$_ POST[te]%' ) "; /sql 语句 
Srs = mysql_query($sqD: /返回 结果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 图 书 编号 </td><td background="pic/head.JPG” 
align="center"> 图 书 名 称 </td><td background="pic/head.JPG" align="center"> 出 版 社 </td><td background="pic/head.JPG" align="center"> 图 书 作者 
</td></tr> 
<php 


> 


while($rst = mysql_fetch row($rs){ /循环 输出 结果 


<tr><td background="pic/head.JPG" align="center"><?php echo S$rst[0]:?></td><td background="pic/head.JPG" align="center"><?php 
echo $rst[1]:?></td><td background="pic/head.JPG" align="center"><?php echo $rst[2]:?></td><td background="pic/head.JPG" align="center"><?php 
echo Srst[31:2></td></tr> 
<?php 


} 


} 
> 


图 秘笈 心 法 
心 法 领悟 428: 实现 实例 的 其 他 方法 。 
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在 上 面 的 实例 中 已 经 提 到 过 ，SQL 语句 有 很 多 种 形式 ， 而 且 不 同 的 SQL 语句 形式 可 以 完成 相同 的 功能 ， 本 
实例 使 用 关键 技术 中 的 SQL 语句 未 免 有 些 麻烦 ， 实 现 此 功能 的 简单 SQL 语句 代码 如 下 : 


select * from tb_demo084 where name like %S_POST[te]96: 


趣味 指数 : 价 侠 催 商 


图 实例 说 明 
本 实例 实现 利用 SQL 语言 中 的 关键 字 in 查找 在 职 或 离职 的 员工 信息 。 运 行 本 实例 ， 如 图 8.101 所 示 ， 首 先 在 
图 中 的 单 选 按钮 中 选择 员工 的 在 岗 情况 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 有 在 职 或 离职 的 员工 信息 显示 出 来 。 


DD Am 
gh 


| 


8.101 由 in 引入 的 关联 子 查询 


图 关键 技术 

由 关键 字 in 引入 的 关联 子 查询 的 语法 格式 如 下 : 

select <column name list> from <table list> where <test expression> in <subquery> 

参数 说 明 : 

column name list: 要 查询 的 列 名 。 

table list: 查询 所 涉及 的 表 名 。 

test expression: 查询 条 件 。 

subquery: 子 查询 。 

本 实例 使 用 关键 字 in 实现 关联 子 查 询 的 SQL 语句 的 代码 如 下 : 

select * from tb_demo085 where work in (select work from tb_demo085 where work='$_POST[click]; 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “查询 ”按钮 时 显示 如 图 8.101 
所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
$conn = mysql_connect("localhost","root","111"); /| 连接 MySQL 
mysql_select_db("db_database08".Sconn): // 连 接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"); // 设 置 编码 集 
if($_POST[sub){ / 单 击 按钮 

// 返 回 结果 集 


Srs= mysql_query("select * from tb_demo085 where work in (select work from tb_demo085 where work='$_POST[click])"); 


> 

<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 ID</td><td background="pic/head.JPG" align="center"> 员 工 姓名 
</td><td background="pic/head.JPG" align="center"> 家 庭 住 址 </td><td background="pic/head.JPG" align="center"> 是 否 在 职 </td></tr> 

<?php 


while($rst = mysql fetch row(Srs)){f /| 循环 输出 结果 
> 
<tr><td background="pic/head JPG" align="center"><?php echo S$rst[01:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[1]:?></td><td background="pic/head. JPG" align="center"><?php echo Srst[2]:?></td><td background="pic/head.JPG" align="center"><?php echo 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(syassort);echo 
iconv("gbk","utf-8",$f->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(newdate):echo 
iconv("gbk","utf-8",$f->value):?></div></td> 
</t> 


<?php 
Srs->movenext: 


力 秘笈 心 法 


心 法 领悟 432: format0 函 数 的 局 限 性 。 
1 于 format0) 函 数 只 适用 于 Access 数据 库 ， 在 正常 程序 开发 过 程 中 ， 只 有 在 使 用 Access 数据 库 的 程序 中 可 


以 偶尔 看 见 此 函数 。 


高 级 | 
趣味 指数 ， 请 容 商 疹 | 


图 实例 说 明 


本 实例 通过 使 用 字符 串 函数 从 学 生 信息 表 中 查找 03 级 全 体 学 生 的 信息 。 运 行 本 实例 ， 如 图 8.105 所 示 ， 单 
击 图 中 的 “查询 ”按钮 即 可 将 03 级 所 有 学 生 的 信息 显示 出 来 。 


在 查询 中 使 用 字符 串 函 数 

Ee 科 日 Ea 
0312101 语文 10 
0312102 E53 回 
0313303 数学 2 
0312104 几何 55 
0312101 fe 2 
0312106 物理 12 


8.105 ”在 查询 中 使 用 字符 串 函数 查询 03 级 学 生 信息 

力 关键 技术 

获取 某 字段 中 指定 位 置 的 字符 串 ， 可 以 通过 函数 mid0 实 现 ， 该 函数 的 使 用 格式 如 下 : 

mid(str,start [Jength]) 

参数 说 明 : 

str: 必要 参数 ， 字 符 串 表 达 式 ， 从 中 返回 字符 ， 如 果 string 包含 null， 将 返回 null。 

start: 必要 参数 ,为 long 型 ,是 指 string 中 被 获取 出 部 分 的 字符 位 置 。 如 果 start 超过 string 的 字符 数 ，midO 
函数 将 返回 零 长 度 字符 。 

length: 可 选 参数 ， 为 variant long， 指 要 返回 的 字符 数 ， 如 果 省 略 或 length 超过 文本 的 字符 数 〈 包 括 start 
处 的 字符 ) ， 将 返回 字符 串 从 start 到 尾 端的 所 有 字符 。 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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在 查询 中 使 用 日 期 函数 


要 所 生日 查 词 员工 年 叭 ， 专 刘 


有 了 纺 叶 下 性 别 EE 
yet 3 要 四 于 条 长 
区 十 去 四 Ee] 
yom 3 更 a 二 补 四 于 


图 8.106 查询 员工 生日 信息 


图 关键 技术 
使 用 DateDiff0 函 数 可 返回 两 个 指定 日 期 的 时 间 间 隔 ， 该 函数 的 语法 格式 如 下 : 


DateDiffinterval ,date1, date2 [firstday of week [firstweek of year]]) 

参数 说 明 : 

interval: 必 选 参数 ， 字 符 串 表达 式 ， 用 来 计算 datel 和 date2 的 时 间 间 隔 。 
datal,date2: 必 选 参数 ， 用 于 指定 具体 日 期 。 

firstday of week: 可 选 参数 ， 指 定 一 年 的 第 一 周 的 常数 ， 如 果 未 指定 ， 则 以 包含 1 月 1 日 的 星期 为 第 一 周 。 


图 设计 过 程 
(1) 建立 conn php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 


<?php 
Sconn=new com("adodb.connection"); // 连 接 数 据 库 
Sconnstr="provider=microsoft.jet.oledb.4.0:data source=" .realpath("./data/db_database08.mdb"): 
$conn->open($connstr); 
> 
(2) 执行 查询 ， 并 通过 函数 DateDiff0 计 算 所 有 员工 的 年 龄 ， 显示 查 询 结 果 ， 代 码 如 下 : 
<?php 
include("conn.php"); /包含 数据 库 连接 文件 
Srs=new com("adodb.recordset"): 
// 查 询 结果 


Srs->open("select ygid.name,sex,address.DateDiff(yyyy’,birthday.DATEO) as age from tb_worker",$conn,3,1): 
if($rs->eofl| $rs->bof) { 
?> 


<t> 

<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"></div></td> 
</t> 
<?php 

Yelsef 

while(!$rs->eof){ 

?> 
<t> 


<td height="25" background—"../089/images/head. JPG"><div align="center"><?php $f-$rs->fields("ygid"): echo 
iconv( gbk','utf-8',$f->value):?></div></td> 
<td height="25" background—"../089/images/head JPG"><div align="center"><?php $f-S$rs->fields("name"); echo 
iconv('gbk','utf-8',$f->value):?></div></td> 
<td height="25" background-" /089/images/head JPG"><div align—"center"><?php $f-S$rs->fields("sex"); echo 
iconv('gbk','utf-8',$f->value); ?></div></td> 
<td height="25" background—"../089/images/head. JPG"><div align="center"><?php $f-$rs->fields("age"”): echo 
iconv(gbk','"utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=$rs->fields("address"); echo 
iconv(gbk','utf-8',$f->value):?></div></td> 
</tr> 
<?php 
Srs->movenext 


} 


> 
</table></td> 
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图 秘笈 心 法 

心 法 领悟 434: 对 DateDiff0 函 数 的 参数 的 解析 。 

DateDiff0 函 数 中 的 参数 interval 用 来 计算 datel 和 date2 的 时 间 间 隔 。 此 参数 可 以 选择 一 些 设 定数 ,例如 yyyy、 
q、m、y 等 。 分 别 表示 年 、 季 、 月 、 一 年 的 日 数 等 。 


组 数据 高 级 | 
。 超 呆 指数 容 克 让 | 


实例 435 


图 实例 说 明 


本 实例 将 统计 员工 信息 表 中 员工 工资 大 于 1500 元 的 员工 职称 。 运 行 本 实例 ， 如 图 8.107 所 示 ， 单 击 图 中 的 
“查询 ”按钮 ， 即 可 将 所 有 工资 在 1500 元 以 上 的 员工 职称 显示 出 来 。 


图 8.107 查询 工资 大 于 1500 元 的 员工 职称 


图 关键 技术 
having 语句 的 语法 格式 如 下 : 


[having <search_condition>] 

参数 <search_condition> 指 定 组 或 聚合 应 满足 的 条 件 。 当 having 与 group by all 一 起 使 用 时 ，having 子 句 可 替 
代 all。 

having search_condition 语句 与 group by 语句 合用 ， 可 用 来 设置 一 些 被 含 入 查询 结果 的 “组 别 ” 所 要 符合 
条 件 。having 语句 可 以 包含 多 个 查询 所 需要 的 条 件 ， 并 且 这 些 过 滤 条 件 之 问 通过 and 或 or 运算 符 相 连接 ， 同 时 
也 可 以 利用 not 运算 符 来 逆转 一 个 布尔 表达 式 。 


图 设计 过 程 
创建 脚本 文件 index.php, 开启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 查 询 ” 按钮 时 ， 显示 如 图 8.107 
所 示 的 内 容 ， 核心 代码 如 下 : 


全 mysql_connect("localhost"."root","111") or die ("Connect MySQL False"): /连接 MySQL 

mysql_select_db("db_database08",$conn); // 连 接 MySQL 数据 库 

mysql_query("SET NAMES utf8"); // 设 置 编码 格式 

if($_GET[id] — "1"){ // 当 地 址 栏 参数 等 于 1 时 
S$rs = mysql_query("select + from tb_demo091 group by id having sal>1500") or die ("false"): /1/ 返 回 结 果 集 

a width="580px"><tr><td background="pic/head.JPG"> 员 工 ID</td><td background="pic/head.JPG"> 员 工 姓名 </td><td 

background="pic/head.JPG"> 员 工 职 称 </td><td background="pic/head.JPG"> 员 工 工资 </td></tr> 
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while($rst = mysql_fetch row($rs){ /循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head. JPG"><?php echo S$rst[11:7></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td><td background="pic/head. JPG"><?php echo S$rst[3]:?></td></tr> 
<?php 

} 


Hi 
> 


力 秘笈 心 法 


心 法 领悟 435: 如 何 使 用 having 子 句 。 
having 子 句 用 于 指定 组 或 聚合 的 搜索 条 件 .having 通 常 与 group by 子 句 一 起 使 用 , 如 果 SQL 语句 中 不 含 group 
by 子 句 ，having 的 行为 与 where 子 名 一样。 


8.8 数据 的 导入 和 导出 


在 对 网 站 的 数据 库 进 行 管理 的 过 程 中 ， 经 常 需要 将 数据 库 中 的 数据 从 一 个 数据 库 导 入 到 另 一 个 数据 库 中 ， 
有 时 还 涉及 到 不 同 数据 库 之 间 的 导入 和 导出 。 


高 级 
趣味 指数 : 俗人 商 商 商 | 


图 实例 说 明 


使 用 PHP 语言 开发 与 数据 库 操作 有 关 的 程序 时 ， 最 佳 搭档 是 MySQL 数据 库 ， 要 在 MySQL 数据 库 中 实现 导 


coe gept ul ate 
1081 PP 2000 2010-07-28 


1015 PP 3000 010-07-18 
1026 PHP 2500 2010-07-28 


8.108 数据 自身 的 导入 和 导出 


图 关键 技术 


实现 数据 导入 和 导出 的 原理 是 : 首先 从 A 数据 库 中 读 取 要 导出 的 数据 ， 并 将 该 数据 输出 到 页 面 中 。 然 后 与 
B 数据 库 建立 连接 ， 将 从 A 数据 库 中 读 取 到 的 数据 存储 到 B 数据 库 指定 的 表 中 。 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 MySQL 数据 库 ， 设 置 页 面 编码 格式 为 tf8， 其 代码 如 下 : 
<?php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); // 连 接 数据 库 服务 器 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"):; // 连 接 数 据 库 
mysql_ query("SET NAMES UTF8"): /设置 数据 库 编码 格式 
> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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SIL server 数 所 


Er Zr | 2 
EI FLOOR | [050 RIZR 
[7000 tA 有 /9 :0 | 15650 IURTIERAY 
图 8.109 导出 SQL Server 数据 图 8.110 创建 MySQL 数据 表 名 称 


图 关键 技术 


本 实例 需要 连接 SQL Server 数据 库 和 MySQL 数据 库 ， 然 后 从 SQL Server 数据 库 的 指定 表 中 读 取 数据 ， 将 
数据 添加 到 MySQL 数据 库 的 指定 表 中 。 连 接 MySQL 和 SQL Server 数据 库 的 方法 如 下 : 


<?php 

$conmn = mssql_connect("PC-201006101638","sa","") or die ("Connect MsSQL False"); /连接 SQL Server 
mssql_select_db("db_database0008",$conn) or die ("Connect Database False”); // 连 接 数 据 库 . 
Scon = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); /连接 MySQL 
mysql_select_db("db_database08",Scon) or die ("Connect Database False”); // 连 接 数 据 库 


mysql query("SET NAMES UTFS8"): 
> 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 分 别 连接 MySQL 和 SQL Server 数据 库 。 

(2) 新 建 ndex.php 文件 。 首 先 ， 通 过 mssql 函数 库 操作 SQL Server 数据 库 ， 查 询 并 输出 SQL Server 指定 
数据 表 中 的 数据 。 然 后 在 MySQL 数据 库 中 创建 一 个 指定 的 数据 表 ， 并 且 将 从 SQL Server 数据 库 中 读 取 的 数据 
添加 到 MySQL 数据 库 的 数据 表 中 ， 其 代码 如 下 : 


?php 

if($_GET[id] = "1"){ /人 单 击 按钮 
include('conn.php); // 包 含 数据 库 连接 文件 
$ms = mssql_query("select * from tb_demo093"); /查询 数据 库 操作 

> 


<table width="580px"><tr><td>SQL Server 数据 信息 </td></tr><tr><td background="pic/head.JPG"><?php echo 
mssql field name($ms,0);?></td><td background="pic/head.JPG"><?php echo mssql field name($ms.1):?></td><td 
background="pic/head.JPG"><?php echo mssql field name($ms.2):?></td><td background="pic/head.JPG"><?php echo 
mssql_field_name(Sms.3):?></td><td background="pic/head.JPG"><?php echo mssql_field_name($ms.4):?></td><td 
background="pic/head.JPG"><?php echo mssql_field_name($ms.5):?></td></tr> 
<?php 

while(Smms = mssql_fetch_array(Sms)){ /循环 输出 结果 
> 


<tr><td background="pic/head.JPG"><?php echo Smmsfid]:?></td><td background="pic/head.JPG"><?php echo 
iconv("gbk","utf-8",$mms[name]):?></td><td background="pic/head.JPG"><?php echo $mms[code]:?></td><td background="pic/head.JPG"><?php 
echo $mms[dept]:?></td><td background="pic/head.JPG"><?php echo $mms[sal]:?></td><td background="pic/head.JPG"><?php echo 
iconv("gbk","utf-8", Smms[date]):?></td></tr> 


<2php 
} 

> 

if($_GET[id] — "2"){ / 单 击 按钮 
include("conn.php"); // 包 含 数据 库 连 接 页 
Srs = mysql_query("select * from tb_demo093"); /查询 数据 库 操作 

> 


<table class="tee" width="580px"><tr><td class="th">MySQL 数据 信息 </td></tr><tr><td background="pic/head.JPG"><?php echo "员工 
ID\".mysql_field_name($rs.0):?></td><td background="pic/head.JPG"><?php echo "员工 姓名 \\".mysql_field_name($rs.1):?></td><td 
background="pic/head.JPG"><?php echo "员工 编号 \W".mysql]_field_name($rs.2):?></td><td background="pic/head.JPG"><?php echo "所 属 部 门 
Weamysql field_name($rs,3):?></td><td background="pic/head.JPG"><?php echo "员工 工资 ("mysql_field_name($rs.4):?></td><td 
background="pic/head.JPG"><?php echo "当前 时 间 \\".mysql field_name($rs,5):?></td></tr> 
<2php 

while($rst = mysql fetch array($rs)){ /循环 输出 结果 
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> 
<tr><td background="pic/head JPG"><?php echo Srst[id]:?></td><td background="pic/head JPG"><?php echo S$rst[name]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[codel:?></td><td background="pic/head. JPG"><?php echo S$rst[dept]l:?></td><td 
background="pic/head.JPG"><?php echo S$rst[sal]:?></td><td background="pic/head JPG"><?php echo Srst[date]:?></td></tr> 


} 


, 
> 


图 秘笈 心 法 

心 法 领悟 437: 连接 SQL Server 数据 库 的 注意 事项 。 

PHP 在 默认 情况 下 ， 是 不 能 连接 SQL Server 数据 库 的 。 为 了 能 够 连接 SQL Server 数据 库 ， 必 须 修 改 php.ini 
文件 的 设置 (在 更 改 文件 前 需要 去 除 该 文件 的 只 读 属性 ) ， 将 :extension=php_mssql.dll 语句 前 的 分 号 删除 ， 然 后 
重新 启动 Apache 服务 器 即 可 。 


实例 438 


图 实例 说 明 


在 对 数据 库 进 行 管理 的 过 程 中 ， 不 同 数据 库 之 间 的 数据 转换 是 很 麻烦 的 ， 本 实例 利用 ADO 连接 Access 数 
据 库 ， 将 Access 数据 库 中 的 数据 导入 到 MySQL 数据 库 中 ， 运 行 结果 如 图 8.111 所 示 。 


CE 于 


hp 
得 出 icces; 扫 所 


fe 
pm 


车 
图 8.111 显示 导入 到 MySQL 的 数据 


本 实例 重点 讲解 如 何 将 PHP 与 Aceess 数据 库 建 立 连接 ,及 如 何 使 用 PHP 语句 从 Aceess 数据 库 中 读 取 数 据 ， 
并 将 数据 添加 到 MySQL 数据 库 中 。 

这 里 使 用 微软 的 ADODB 数据 库 驱 动 实现 PHP 与 Aceess 数据 库 的 连接 。PHP 是 通过 预定 义 类 com 来 使 用 
ADO 方法 操纵 Access 数据 库 的 ， 该 类 的 详细 说 明 如 下 : 

string com::com( string module_name [. string server_name [, int codepage]]) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 。 

Codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 -该 参数 的 取 值 有 CP_ACP、 
CP MACCP、CP OEMCP、CP SYMBOL、CP_ THREAD ACP、CP_UTF7 和 CP_UTF&8。 

PHP 利用 com 类 并 使 用 ADO 方法 访问 数据 库 的 代码 如 下 : 

Need com("adodb.connection"); 

Sconnstr—"provider—microsoft.jet.oledb.4.0:data source—" realpath("./data/score .mdb"): 

SP 
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图 设计 过 程 


(1) 新 建 conn.php 文件 ， 完 成 与 Access 数据 库 和 MySQL 数据 库 的 连接 ， 其 代码 如 下 : 
<2php 
S$conn=new com("adodb.connection"); 
$connstr="provider=microsoftjet.oledb.4.0:data source—".realpath("Access database/db_demo094.mdb"); 
$conn->open($connstr); 
Srs=new com("adodb.recordset"); 
$con = mysql connect("localhost","root"."111") or die ("Connect MySQL False"); 
mysql_select_ db("db_database08".Scon) or die ("Connect Database False"): 
mysql_query("SET NAMES UTFS8"): 
> 


(2) 新 建 index.php 文件 ， 首 先 查 询 Access 数据 库 ， 完 成 Access 数据 库 中 数据 的 循环 输出 ， 其 代码 如 下 : 


<php 

if($_GET[id] =—"1"){ / 单 击 按钮 
include("conn.php"); // 包 含 数据 库 连 接 文 件 
Srs->open("select * from tb_demo094".Sconn): // 返 回 结果 集 
if($rs->eofl| $rs->bof){}else{ 

> 

Access 数据 信息 

<php 

while(!$rs->eoD){ /循环 输出 结果 
> 


<b> 

<td><?php $ 全 Srs->fields(id):echo iconv("gbk","utf-8",$f->value);?></td><td><?php $f=$rs->fields(name);echo iconv("gbk","utf-8",$f->value);?></td> 
<td><?php $f=$rs->fields(dept):echo iconv("gbk","utf-8",$f->value);?></td><td><?php $f=$rs->fields(sal);echo iconv("gbk","utf-8",$f->value);?></td> 
<td><?php $f=$rs->fields(date):echo iconv("gbk","utf-8",$f->value):?></td> 

<t> 


<?php 
Srs->movenext; 
} 
} 
> 
<form action="" method="post"> 
<input type="text" name="te" value=" 创 建 导入 MySQL 数据 表 名 称 " onfocus="this value= class="one" /> 
<input type="submit" name="sub" Value="&nbsp;" class="two" /> 
</fom> 
<?php 
} 
> 
(3) 将 Access 数据 库 中 的 数据 通过 SQL 语句 插入 到 MySQL 数据 库 中 ， 并 且 循环 输出 MySQL 数据 库 中 
的 数据 ， 其 代码 如 下 : 
if($_GET[id] = "2"){ / 单 击 按钮 
include("conn.php"): // 包 含 数据 库 连 接 页 
Srs = mysql_query("select * from tb_demo094"): // 返 回 结果 集 
> 
<table width="580px"> 
<tr> 


<td class="th">MySQL 数据 信息 </td></tr> 
<tr><td background="pic/head.JPG">id</td> 
<td background="pic/head.JPG">name</td> 
<td background="pic/head.JPG">dept</td> 
<td background="pic/head.JPG">sal</td> 
<td background="pic/head.JPG">date</td> 
<t> 


while($rst = mysql fetch_array($rs)){ /| 循环 输出 结果 
> 
<tr> 
<td background="pic/head.JPG"><?php echo Srst[id]:?></td> 
<td background="pic/head JPG"><?php echo $rst[name]:?></td> 
<td background="pic/head.JPG"><?php echo $rst[dept]:?></td> 
<td background="pic/head.JPG"><?php echo $rst[sal]:?></td> 
<td background="pic/head.JPG"><?php echo S$rst[date]:?></td> 
</t> 
<?php 


585 
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上 


> 


图 秘笈 心 法 

心 法 领悟 438: ActiveX Data Objects (ADO) 。 

ActiveX Data Objects (ADO) 是 Microsoft 开放 数据 库 应 用 程序 的 数据 库 访 问 技 术 ， 它 被 设计 用 来 同 新 的 数 
据 访问 层 OLE DB Provider 一 起 协同 工作 ， 提 供 通用 数据 访问 (Universal Date Access) 。OLE DB 是 一 个 低层 
的 数据 访问 接口 ， 用 它 可 以 访问 各 种 数据 源 ， 包 括 传统 的 关系 型 数据 库 、 电 子 邮 件 系统 及 自 定义 的 商业 对 象 。 
ADO 技术 大 大 简化 了 OLE DB 的 操作 ， 因 为 ADO 封装 OLE DB 程序 中 使 用 的 大 量 COM 接口 ， 所 以 ADO 是 

-种 高 层 的 访问 技术 。 


8.9 MySQL 数据 库 的 备份 和 恢复 


MySQL 数据 库 的 功能 是 非常 强大 的 ， 为 确保 数据 库 中 数据 的 安全 ， 对 数据 定期 进行 备份 是 很 重要 的 。 


实例 439 趣味 指数 : 窗帘 俩 窗 | 


图 实例 说 明 


在 命令 行 模式 下 可 以 实现 创建 、 修 改 、 删 除数 据 库 、 数 据 表 及 数据 表 中 的 数据 信息 的 操作 。 同 样 也 可 以 在 
命令 模式 下 对 数据 库 进行 备份 , 可 通过 Mysql dump 命令 将 整个 数据 库 备 份 到 指定 文件 夹 下 的 文本 文件 中 , 其 运 
行 效果 如 图 8.112 和 图 8.113 所 示 。 


=I9lxl 


EEC ET ETT ET 
~ MUSOL dump 19.13 Distrib 5 


1 ,For Win32 (ia32) 


Server version EE 


/urA0101 SET GOLD_CHARACTER_SET_CLIENT GCHARACTER_ SET_CLIENT si 
eae181 SET @OLD_CHARACTER_SET_RESULTS=@RCHARACTER_SET_RESULTS «/; 
由 站 HU COLLATION CONNECTION=@@COLLATION_CONNECTION */; 
a /3 


NECk: 
/+40014 SET QOLD_FORCIGN KEY_CHECKS-G@F DREIGH_KEY_CHECKS, 
JFOREIGH_KEY_CHECKS=@ =/; 

era SET entp_sqL_mnpE-aasqt_mnpE， 

SQL_HODE=* HO_AUTO_UALUE_ON_ZERO* */- 


/ee111 SET @OLD_SQL NOTES-GaSQL NOTES, SQL NOTES=0 #/; 国 


图 8.112 cmd 命 令 备份 数据 库 图 8.113 文本 文件 备份 数据 库 内 容 


图 关键 技术 
在 命令 模式 下 实现 对 数据 库 的 备份 ， 应 用 的 是 Mysql dump 命令 ， 其 语法 如 下 : 
Mysqldump —uroot -p111 db_database08 > D:\db_databaseO8.txt: 
图 设计 过 程 
执行 备份 操作 的 步骤 如 下 : 
(1) 选择 “开始 ”菜单 中 的 “运行 ”命令 。 
(2) 在 弹出 的 对 话 框 的 文本 框 中 输入 cmd， 单 击 “ 确 定 ” 按 钮 ， 进 入 命令 模式 。 
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(3) 在 命令 模式 中 直接 输入 mysqldump -uroot -p111 db _database08 > db _database08 txt， 然 后 按 Enter 键 即 可 。 

其 中 ，-uroot 中 的 root 是 用 户 名 ， 而 -p111 中 的 111 是 数据 库 密码 ; db _database08 是 数据 库 名 称 ; 
D:\db_database08.txt 是 数据 库 备 份 的 存储 位 置 。 
图 秘笈 心 法 

心 法 领悟 439: 手动 设置 环境 变量 。 

在 命令 模式 下 操作 MySQL 数据 库 ， 最 好 先 对 计算 机 的 环境 变量 进行 设置 。 右 键 单 击 “ 我 的 电脑 ”图 标 ， 
从 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ， 在 弹出 的 对 话 框 中 单 击 “ 高 级 ”按钮 ， 然 后 在 新 弹出 的 对 话 框 中 选择 
“环境 变量 ”选项 ， 并 在 用 户 变量 的 文本 框 中 找到 变量 “path” 并 将 其 选中 ， 单 击 “ 编 辑 ” 按 钮 ， 在 变量 path 
的 变量 值 文 本 框 中 输入 路 径 F:xwampp\xampp\mysql\bin(MySQL 数据 库 中 bin 文件 夹 的 安装 路 径 ), 然后 单 击 “ 确 
定 ” 按 钮 。 其 中 添加 的 bin 文件 夹 的 路 径 根据 安装 MySQL 数据 库 的 位 置 而 定 。 


a 


实例 440 昌 i 


力 实例 说 明 


备份 MySQL 数据 库 的 操作 可 以 在 命令 模式 下 实现 ， 也 可 以 通过 phpMyAdmin 图 形 化 管理 工具 来 实现 。 
phpMyAdmin 为 Web 开发 人 员 提 供 类 似 Access、SQL Server 的 图 形 化 数据 库 操 作 界 面 ， 通 过 该 管理 工具 可 
以 进行 绝 大 部 分 的 MySQL 操作 ， 包 括 对 数据 库 及 数据 表 的 建立 和 维护 。 


图 关键 技术 


本 实例 运用 phpMyAdmin 图 形 化 管理 工具 完成 对 数据 库 的 备份 操作 。 在 备份 数据 库 之 前 ， 首 先 选 择 需要 备 
份 的 数据 库 ， 然 后 根据 导航 栏 的 提示 实现 数据 库 备 份 即 可 。 


图 设计 过 程 
通过 phpMyAdmin 图 形 化 管理 工具 备份 数据 库 ， 既 可 以 备份 整个 数据 库 ， 也 可 以 备份 数据 库 中 的 一 个 表 。 


(1) 打开 phpMyAdmin 图 形 化 管理 工具 ， 在 地 址 栏 输入 http://127.0.0.1/phpMyAdmin/， 进 入 到 如 图 8.114 
所 示 的 页 面 中 。 


BE 3soL 帮 基 才 。 问 于 且 。 站 下 生 天 及 引 里 的 权 用 二 是 
PCr 
二 作 
Si 
Eo 
Mysot localhost 
Eb 


硬 一 一 一 习 况 | 
EE Err] 
和 


[et mT 


图 8.114 phpMyAdmin 图 形 化 管理 工具 的 页 面 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 秘笈 心 法 

心 法 领悟 441: 处 理 不 同 版 本 数据 库 的 差异 。 
由 于 使 用 的 MySQL 数据 库 的 版 本 不 同 , 在 进行 备份 时 ， 有 的 版 本 需要 停止 MySQL 服务 后 ， 才 可 以 备份 文 
件 ， 以 XAMPP 为 例 ， 启 动 和 停止 MySQL 服务 的 方法 如 图 8.117 所 示 。 


= 上 车 

mi XAMPP Control Panel Shell 

[ee 一 一 
p 

Fodue 一 一 [eort-Check 
回 sve Apache Running Explore 
回 sw MySql Running SCM 
Refresh 
Help 
EM 

习 


| 
| 评 页 二 司 


图 实例 说 明 
本 实例 将 介绍 通过 命令 模式 恢复 数据 库 的 方法 ， 它 针对 的 是 实例 439 中 通过 命令 模式 备份 数据 库 的 操作 。 
图 关键 技术 


通过 命令 模式 恢复 数据 库 使 用 的 是 mysql -uroot -p111 db_database08 < D:\db_database08.txt 命令 ， 其 中 -uu 后 
的 root 代表 用 户 名 ，-p 后 的 root 代表 密码 ，db_database08 代表 数据 库 名 称 (或 表 名 ) ，“<” 号 后 面 的 
D:db_database08.txt 是 数据 库 备份 文件 存储 的 位 置 。 


| | 设计 过 程 
在 命令 模式 下 恢复 整个 数据 库 文件 ， 命 令 如 下 : 


Ci\Documents and Setting\Administrator > mysql -uroot -p111db_database08 < D:\db_databaseO08.txt: 

该 命令 的 操作 步骤 如 下 : 

(1) 选择 “开始 ”菜单 中 的 “运行 ”命令 。 

(2) 在 弹出 的 对 话 框 中 输入 cmd 命令 ， 单 击 “确定 ”按钮 ， 进 入 命令 模式 。 

(3) 在 命令 模式 中 直接 输入 mysql -uroot -p111 db_database08 < D:\db_database08.txt， 然 后 按 Enter 键 ， 即 
可 实现 数据 库 的 恢复 ， 运 行 效果 如 图 8.118 所 示 。 


力 秘笈 心 法 


心 法 领悟 442: 命令 行 下 备份 和 恢复 数据 库 的 缺点 。 
于 此 种 备份 和 恢复 数据 库 的 方法 都 是 要 依托 客户 机 硬盘 上 的 文本 文件 ， 而 文本 文件 是 以 明文 的 方式 保存 
数据 库 信息 的 ， 所 以 安全 性 较 低 。 
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图 8.118 命令 行 下 恢复 数据 库 数据 


phpMyAdmin 恢复 数据 库 


光盘 \MIR\08\443 趣味 指数 :会 请 请 请 : 


实例 443 


图 实例 说 明 

本 实例 介绍 通过 phpMyAdmin 图 形 化 管理 工具 恢复 数据 库 的 方法 , 它 针对 的 是 实例 440 中 通过 phpMyAdmin 
图 形 化 管理 工具 备份 数据 库 的 操作 。 
图 关键 技术 

本 实例 的 操作 方法 十 分 简单 ， 相 关 技 术 已 经 在 实例 440 中 介绍 过 了 ， 这 里 不 再 袭 述 。 

在 执行 恢复 数据 库 的 操作 时 ， 首 先 必须 在 pppMyAdmin 图 形 化 管理 工具 中 选中 一 个 数据 库 ， 然 后 再 执行 导 
入 文件 的 操作 。 

设计 过 程 

通过 phpMyAdmin 图 形 化 管理 工具 恢复 数据 库 的 步骤 如 下 : 

(1) 打开 phpMyAdmin 图 形 化 管理 工具 ， 在 该 界面 左 侧 窗口 的 下 拉 菜 单 中 选择 要 恢复 的 数据 库 。 

(2) 在 phpMyAdmin 图 形 化 管理 工具 操作 界面 的 左 侧 窗 口中 单 击 SQL 查询 窗口 按钮 ， 进 入 界面 ， 在 查询 
窗口 中 单 击 “ 导 入 文件 ”按钮 ， 根 据 提示 浏览 文本 文件 所 在 的 位 置 ， 找 到 该 文件 后 ， 单 击 “执行 ”按钮 即 可 。 
图 秘笈 心 法 

心 法 领悟 443: phpMyAdmin 图 形 化 管理 工具 的 版 本 差异 。 
phpMyAdmin 图 形 化 管理 工具 因 版 本 不 同 ， 实 现 导入 文本 文件 的 方法 也 不 相同 ， 但 实现 步骤 大 致 相同 。 


590 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 1200 例 (第 I 卷 ) 


了 的 操作 界面 ， 使 程序 员 在 设计 MySQL 数据 库 时 变 得 简单 。phpMyAdmin 几乎 可 以 实现 操作 数据 库 的 所 有 功 
能 。 本 实例 将 演示 如 何 通 过 phpMyAdmin 修改 MySQL 用 户 密码 。 


图 关键 技术 


通过 phpMyAdmin 修改 MySQL 用 户 的 密码 可 以 通过 两 种 方法 实现 : 

(1) 直接 通过 phpMyAdmin 的 界面 进行 更 改 。 

(2) 通过 修改 phpMyAdmin 文件 夹 下 的 配置 文件 config.php 实现 更 改 。 
图 设计 过 程 

通过 修改 配置 文件 进行 密码 修改 。 

(1) 将 下 载 的 pppMyAdmin-x.zip 文件 解压 到 Apache 默认 的 根 目 录 下 ， 解 压 后 的 名 称 是 phpMyAdmin- 
2.X.XX， 其 中 的 2.x.x.x 是 版 本 号 ， 为 方便 使 用 ， 可 以 将 其 重新 命名 为 pppMyAdmin。 


(2) 打开 phpMyAdmin 文件 夹 ， 找 到 配置 文件 config php， 然 后 使 用 记事 本 或 其 他 编辑 工具 打开 该 文件 ， 
找到 该 文件 中 的 以 下 内 容 进 行 配置 : 
Scfe[PmaAbsoluteUri] = http://127.0.0.1/phpMyAdmin': 
以 上 用 于 设置 phpMyAdmin 的 URL， 例 如 http://127.0.0.1/phpMyAdmin。 
$cfg[blowfish_secret] = Yoot': 
在 上 述 语句 中 更 改 用 户 密码 ， 例 如 root。 
Scfeg['Servers'][$i]['controluser’] = root'; 
$cfg['Servers'1[$il['controlpass1= root: 
$cfg['Servers'][$il[user] = root': 
Scfe['Servers'][$i]['password’] = 'root'; 
(3) 完成 配置 后 保存 该 文件 。 
回 ”通过 phpMyAdmin 的 界面 进行 密码 修改 。 
(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 单 击 “ 修 改 密码 ” 按钮 ， 如 图 8.119 所 示 。 
(2) 根据 页 面 提示 输入 新 密码 和 确认 密码 ， 如 图 8.120 所 示 。 
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图 8.119 phpMyAdmin 图 形 化 界面 8.120 修改 MySQL 数据 库 密码 
(3) 单 击 “ 执 行 ”按钮 ， 修 改 MySQL 数据 库 密码 ， 如 图 8.121 所 示 。 
图 秘笈 心 法 


心 法 领悟 445: phpMyAdmin 图 形 化 管理 工具 的 优点 。 

phpMyAdmin 图 形 化 管理 工具 几乎 是 所 有 的 PHP+MySQL 用 户 必 备 的 利器 之 一 ， 其 优点 是 : 
(1) 程序 本 身 由 PHP 语言 编写 ， 并 且 是 开源 的 ， 对 于 PHP 编程 爱好 者 来 说 ， 再 适合 不 过 。 
(2) 工具 虽然 免费 ， 但 功能 并 不 欠缺 ， 它 可 以 很 完美 地 完成 对 MySQL 数据 库 的 各 种 操作 。 
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8.121 ”完成 密码 修改 
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力 实例 说 明 


将 页 面 、 程 序 文件 、 数 据 库 与 数据 表 设置 为 统一 的 编码 格式 可 以 避免 程序 运行 时 出 现 乱码 。 一 般 情 况 下 ， 
设置 页 面 的 编码 格式 由 HTML 中 的 <meta> 标 签 实现 ， 设 置 程序 文件 的 编码 格式 由 mysql_query0 实 现 , 设置 数据 
库 与 数据 表 的 编码 格式 通过 phpMyAdmin 实现 。 


力 关键 技术 

本 实例 的 操作 方法 十 分 简单 ， 在 创建 数据 库 名 称 时， 在 “整理 ”下 拉 列 表 中 选择 需要 设置 的 编码 格式 ;在 
创建 数据 表 时 ， 同 样 将 数据 字段 设置 为 统一 的 编码 格式 。 
图 设计 过 程 


(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 创 建 数据 库 名 称 ， 选 择 编码 格式 ， 如 图 8.122 所 示 。 
(2) 创建 数据 表 ， 定 义 数 据 表 字段 ， 并 设置 编码 格式 ， 如 图 8.123 所 示 。 
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图 8.122 设置 数据 库 编 码 格式 图 8.123 设置 字段 编码 格式 
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力 秘笈 心 法 

心 法 领悟 446: 设置 统一 的 编码 格式 。 

在 创建 数据 表 字 段 时 ， 一 般 将 字符 类 型 的 数据 字段 设置 为 统一 的 编码 格式 ， 对 于 数值 型 数据 字段 ， 可 以 不 
进行 编码 格式 的 设置 。 


实例 447 


图 实例 说 明 

phpMyAdmin 可 以 实现 在 cmd 命令 行 下 对 数据 库 的 操作 , 而 且 操作 更 简单 直观 。 本 实例 通过 phpMyAdmin 
实现 对 数据 库 的 创建 和 删除 操作 。 
图 关键 技术 

切记 ， 在 创建 数据 库 时 ， 一 定 要 设置 数据 库 的 编码 格式 。 注 意 ， 一 旦 执行 删除 操作 ， 数 据 库 将 不 能 再 恢复 。 
图 设计 过 程 

(1) 登录 到 phpMyAdmin 主页 ， 根 据 提示 编写 新 建 数据 库 的 名 称 ， 并 设置 数据 库 的 编码 格式 ， 如 图 8.124 
Ce 单 击 “ 创 建 ” 按 钮 ， 创 建 数据 库 并 自动 选择 创建 的 数据 库 为 当前 数据 库 。 


(3) 如 果 数 据 库 已 经 没有 任何 作用 ， 可 以 通过 phpMyAdmin 删除 数据 库 。 选 择 想 要 删除 的 数据 库 ， 单 击 导 
航 栏 中 的 “删除 ”按钮 ， 根 据 提示 决定 是 否 删除 ， 如 图 8.125 所 示 。 
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图 8.124 创建 数据 库 图 8.125 ”删除 数据 库 
力 秘笈 心 法 


心 法 领悟 447: phpMyAdmin 图 形 化 工具 与 cmd 命令 下 操作 数据 库 。 
通过 phpMyAdmin 图 形 化 工具 与 在 cmd 命令 下 操作 数据 库 没 有 任何 区 别 ， 只 是 phpMyAdmin 的 设计 者 对 
MySQL 数据 库 的 相关 指令 进行 了 封装 ， 使 一 些 对 MySQL 数据 库 不 甚 了 解 的 用 户 也 可 以 操作 数据 库 。 
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高 级 


实例 448 te a 


图 实例 说 明 


对 数据 表 的 操作 一 般 包 括 创 建 和 删除 ， 本 实例 介绍 应 用 phpMyAdmin 图 形 化 工具 实现 对 数据 表 的 创建 和 删 
除 操作 。 


力 关键 技术 


想 要 创建 数据 表 ， 首 先 要 创建 数据 库 ， 当 数据 库 创 建 完成 时 自动 选择 已 经 创建 好 的 数据 库 ， 根 据 提示 编写 
数据 表 名 称 并 创建 数据 表 。 而 删除 数据 表 时 ， 需 要 选择 想 要 删除 的 表 ， 然 后 单 击 “ 删 除 ” 按 钮 即 可 完成 。 


图 设计 过 程 


(1) 登录 到 phpMyAdmin 界面 ， 创 建 数据 库 ， 选 择 数据 库 编码 格式 ， 单 击 “ 创 建 ”按钮 ， 根 据 提 示 编 写 数 
据 表 名 称 ， 并 填写 想 要 创建 数据 表 的 字段 数目 ， 如 图 8.126 所 示 。 

(2) 进入 编写 数据 库 字 段 页 ， 建立 数据 表 结 构 ， 填 写字 段 信息 ， 其 中 包括 字段 名 称 、 字 段 类 型 、 字 段 长 度 、 
是 否 允 许 为 3 加 8.127 
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图 8.126 ”创建 数据 表 图 8.127 创建 数据 表 结构 


(3) 单 击 “保存 ”按钮 ， 完 成 数据 表 的 创建 。 
(4) 删除 数据 表 时 ， 首 先 选 择 要 删除 的 数据 表 名 称 ， 并 进入 数据 表 操 作 界面 ， 单 击 导 航 栏 中 的 “删除 ” 按 
钮 ， 根 据 提示 删除 数据 表 ， 如 图 8.128 所 示 。 


力 秘笈 心 法 
心 法 领悟 448: 使 用 phpMyAdmin 图 形 化 工具 创建 数据 表 的 注意 事项 。 


在 创建 数据 表 结 构 时 也 要 对 数据 表 字 段 进行 编码 格式 设置 ， 而 且 必 须 为 数据 表 指 定 主键 、 设 置 索引 ， 和 否则 
会 出 现 如 图 8.129 所 示 的 提示 内 容 。 
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图 8.128 ”删除 数据 表 图 8.129 没有 定义 索引 
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力 实例 说 明 


对 MySQL 数据 库 中 数据 的 操作 包括 插入 、 删 除 、 修 改 和 查询 等 。 本 实例 将 介绍 如 何 通过 phpMyAdmin 图 


形 化 管理 工具 完成 上 述 的 操作 。 


图 关键 技术 


phpMyAdmin 图 形 化 管理 工具 操作 数据 的 关键 点 如 下 : 
查询 数据 信息 : 进入 表 名 为 也 _demo (以 tb_demo 为 例 ) 的 数据 表 界面 ， 单 击 导 航 栏 中 的 “浏览 ”按钮 。 
插入 数据 信息 : 单 击 导 航 栏 中 的 “插入 ”按钮 ， 根 据 提示 插入 信息 。 


图 设计 过 程 


(1) 查询 数据 信息 。 首 先进 入 tb_demo 数据 表 ， 默认 情况 下 直接 显示 数据 表 的 信息 。 如 果 刚 刚 进行 完 其 他 
操作 ， 则 单 击 导航 栏 中 的 “浏览 ”按钮 ， 显 示 数 据 表 信息 ， 如 图 8.130 所 示 。 
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图 8.130 查询 数据 信息 
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(2) 插入 数据 信息 。 单 击 导航 栏 中 的 “插入 ”按钮 ， 进 入 插入 信息 界面 ， 完 成 数据 的 添加 ， 单 击 “ 执 行 ” 
按钮 ， 实 现 插入 数据 ， 如 图 8.131 所 示 。 

(3) 删除 数据 信息 。 首 先 返回 到 数据 浏览 页 ， 如 果 要 删除 单条 数据 信息 ， 直 接 单 击 该 条 数据 的 删除 按钮 ; 
如 果 要 删除 多 条 数据 信息 ， 可 以 选中 数据 信息 前 端的 复 选 框 ， 然 后 单 击 数据 表 信 息 下 端的 “选中 项 删除 ”按钮 ; 
如 果 要 删除 数据 表 中 的 所 有 信息 ， 可 以 单 击 导航 栏 中 的 “清空 ”按钮 ， 实 现 删除 所 有 数据 信息 ， 如 图 8.132 
所 示 。 
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图 8.131 插入 数据 信息 图 8.132 ”删除 数据 操作 


(4) 修改 数据 信息 。 修改 数据 信息 与 删除 数据 信息 类 似 , 可 以 分 为 修改 单条 数据 信息 和 修改 多 条 数据 信息 。 
修改 单条 数据 信息 时 直接 单 击 该 条 数据 的 修改 按钮 进入 修改 页 面 ， 即 可 实现 修改 ;修改 多 条 数据 信息 时 ， 首 先 
要 勾 选 复 选 框 ， 然 后 单 击 “ 选 中 项 修改 ”按钮 ， 进入 修改 页 面 ， 成 修改 ， 如 图 8.133 和 图 8.134 所 示 。 
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图 8.133 ”修改 数据 信息 图 8.134 更 改 数据 信息 页 


力 秘笈 心 法 


心 法 领悟 449: 在 phpMyAdmin 图 形 化 界面 工具 中 修改 操作 与 删除 操作 的 区 别 。 

如 果 在 修改 多 条 数据 时 ， 误 选中 不 需 更 改 的 数据 信息 前 的 复 选 框 ， 进 入 修改 页 面 后 可 以 不 对 此 条 数据 做 任 
何 修改 ， 此 条 数据 信息 不 会 有 任何 变化 。 但 是 如 果 在 删除 多 条 数据 时 ， 误 选中 不 需 删除 的 数据 信息 前 的 复 选 框 ， 
则 单 击 “执行 ”按钮 ， 信 息 会 被 删除 。 
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第 9 章 MySQL 高 级 应 用 技术 
9.1 PHP 的 MySQLi 扩展 库 


在 PHP 5.0 以 后 的 版 本 中 , 为 适应 MySQL 数据 库 的 新 特性 重新 编写 了 MySQLi 扩展 库 。MySQLi 扩展 库 同 
时 提供 了 面向 过 程 和 面向 对 象 的 两 种 调用 接口 ， 本 节 将 通过 具体 实例 讲解 如 何 使 用 MySQLi 扩展 库 对 MySQL 
数据 库 进 行 操作 。 
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图 实例 说 明 
本 实例 主要 实现 使 用 MySQLi 扩展 库 的 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 。 运 行 本 实例 ， 如 
图 9.1 所 示 ， 在 页 面 中 打印 出 数据 库 连接 成 功 的 提示 信息 ， 从 而 说 明 已 经 成 功 连接 上 MySQL 数据 库 。 


www.mrbccd.com 


数据 压 连 接 成 功 
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图 9.1 数据 库 连 接 成 功 


图 关键 技术 

使 用 MySQLi 扩展 库 的 面向 对 象 的 方法 建立 与 MySQL 数据 库 的 连接 ， 主 要 是 使 用 mysqli 类 实现 的 ， 该 类 
的 构造 方法 的 语法 格式 如 下 所 示 : 

class mysqlif 

i et st) 

mysqli 类 的 构造 方法 的 参数 说 明 ， 如 表 9.1 所 示 。 


表 9.1 类 mysqli 构造 方法 的 参数 说 明 


参数 名 称 说 了 明 
host MySQL 数据 库 服 务 器 名 称 
username MySQL 数据 库 服 务 器 用 户 名 
asswd MySQL 数据 库 服 务 器 密码 
dbname 要 连接 的 MySQL 数据 库 的 名 称 
ort MySQL 数据 库 服务 器 端口 号 ， 默 认为 3306 
图 设计 过 程 


(1) 创建 数据 库 db_database09。 在 MySQL 中 创建 数据 库 可 以 通过 SQL 语句 或 phpMyAdmin 图 形 化 管理 
工具 实现 ， 本 实例 将 采用 命令 方式 创建 MySQL 数据 库 ， 其 创建 代码 如 下 所 示 : 


CREATE DATABASE "db _database09 : 


(2) 使 用 函数 parse_ini file0 解 析 配 置 文件 config.ini 以 获得 数据 库 连接 参数 ,然后 使 用 new 关 键 字 对 mysqli 
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类 进行 实例 化 , 最 后 使 用 函数 mysqli connect_ermo0 来 判断 是 否 成 功 连接 上 了 MySQL 数据库, 实现 该 过 程 的 代 


码 如 下 所 示 : 
ty{ 
Sconfig = parse_ini file(realpath(dimame( FILE_).'/config/config.ini)): // 解 析 config.ini 文 件 
Smysqli = new mysqli($config['host]. Sconfig[usemame']. Sconfig[password]. $config['dbname]): /对 mysqli 类 进行 实例 化 
这 mysqli_connect_ermoO){ // 济 断 是 否 成 功 连接 上 MySQL 数据 库 
throw new Exception(<br> 数 据 库 连 接 错 误 ! 小 // 如 果 连 接 错误 ， 则 抛 出 异常 
Jelsef 
echo 数据 库 连接 成 功 ! /打印 连接 成 功 的 提示 
} 
}catch (Exception $e){ /捕获 异常 
echo $e->getMessage(); /打印 异常 信息 
} 
< 注意 : 使 用 MySQLi 扩展 库 完 成 对 MySQL 数据 库 的 操作 后 , 还 应 该 通过 调用 MySQLi 类 实例 对 象 的 close0 
图 秘笈 心 法 


心 法 领悟 450: 使 用 MySQLi 扩展 库 的 面向 过 程 的 方式 连接 MySQL 数据 库 。 

使 用 MySQLi 扩展 库 不 仅 可 以 采用 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 ， 为 了 适应 不 同 开发 习惯 
用 户 的 需求 ， 同 时 提供 了 面向 过 程 的 方式 对 MySQL 数据 库 进 行 管理 。 使 用 MySQLi 面向 过 程 的 方式 建立 与 
MySQL 数据 库 的 连接 是 通过 mysqli_connect0 函 数 实现 的 ， 该 函数 的 语法 格式 如 下 : 

mysqli_connect( [string host [, string usermame [, string passwd [, string dbname [. int port]]]]] ) 

该 函数 参数 的 使 用 方式 与 mysqli 类 的 构造 方法 相同 ， 这 里 不 再 歼 述 。 


实现 数据 库 信息 的 检索 初级 | 


实例 451 


图 实例 说 明 


在 Web 项 目 开发 过 程 中 ， 经 常 需要 对 大 量 数据 信息 进行 查询 操作 ， 本 实例 主要 介绍 如 何 使 用 MySQLi 扩展 
技术 实现 商品 信息 的 检索 。 运 行 本 实例 ， 如 图 9.2 所 示 ， 在 图 中 文本 框 中 输入 要 查找 的 商品 名 称 ， 单 击 “ 查 找 ” 
按钮 ， 如 果 该 商品 存在 则 显示 该 商品 的 所 有 信息 ， 否 则 提示 没有 查找 到 该 商品 。 


今天 是 z010 年 7 月 z5 日 星期 三 


[ 请 给 入 商品 名 称 : 刁 示 下 EE 
| 商品 名称 商品 价格 商品 数量 进货 日 期 
显示 卡 50 34 2007-0420000000 


图 9.2 商品 信息 查询 


力 关键 技术 


在 MySQLi 扩展 库 的 面向 对 象 的 编程 方式 中 ， 可 以 使 用 mysqli 类 中 的 query0 方 法 执行 查询 操作 ,该 方法 的 
语法 格式 如 下 所 示 : 

mixed query ( string query [. int resultmode] ) 

参数 说 明 : 

query: 要 执行 的 查询 语句 。 
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resultmode: 用 于 指定 结果 模式 ， 这 里 可 以 取 MYSQLI STORE RESULT 和 MYSQLI USE _ RESULT 两 个 
值 , 使 用 MYSQLI USE RESULT 时 在 执行 下 一 条 查询 前 必须 调用 mysqli_result 的 free0 方 法 或 close0 方 法 释放 
查询 结果 对 象 ， 否 则 查询 失败 。 如 果 执 行 查询 返回 结果 数据 量 较 大 一 般 使 用 MYSQLI USE RESULT。 
图 设计 过 程 

(1) 建立 如 图 9.2 所 示 的 商品 信息 管理 页 面 ， 在 页 面 中 建立 按 商 品名 称 查 询 商 品 信息 的 表单 ， 该 页 面 的 创 
建 代 码 请 详 见 本 书 附带 光盘 ， 同 时 建立 conn.php 文件 实现 与 数据 库 的 连接 ， 该 文件 的 代码 如 下 : 


$conn=new mysqli(“localhost”,"root",”111”."db_database09"): /建立 与 数据 库 的 连接 
Sconn->query("set names utf8"); /设置 数据 库 字符 集 


(2) 当 用 户 单 击 表单 中 的 “查找 ”按钮 后 , 将 通过 如 下 代码 按照 用 户 在 表单 中 录入 的 关键 字 进 行 匹 配 查 询 。 
在 下 述 代码 中 ， 首 先 判断 用 户 是 否 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 include_once 语句 包含 conn.php 文件 ， 然 
后 使 用 mysqli 类 实例 后 的 对 象 调用 query0 方 法 执行 查询 ， 并 使 用 执行 查询 后 的 返回 对 象 调用 fetch_array0 方 法 
获得 查询 结果 集 ， 如 果 结 果 集 不 为 空 则 在 页 面 中 打印 结果 集 ， 反 之 打印 未 查询 到 结果 的 提示 信息 。 


<?php 

if($_POST[submit]!="") /1 判断 用 户 是 否 提交 了 表单 
include_once("conn.php"); // 包 含 conn.php 文件 
Sname=$_POST[name]; // 获 得 提交 关键 字 
$sql=$conn->query("select * from tb_goods where name like '%6".$name."96"); /执行 查询 
Sinfo=$sql->fetch_array(MYSQLIL ASSOC): / 苇 得 查询 结果 集 
if($info—NULL){ 

echo "<div align=center> 没 有 查找 到 该 商品 !</div>"; 

jelsef 


> 
<!--- 省 略 代码 ， 请 参见 本 书 附带 光盘 -> 


dof // 通 过 循环 显现 查询 结果 
> 
<t> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[name];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $infofpricel:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[shuliang]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[addtime]:?></div></td> 
</r> 
php 


} 
while($info=$sql->fetch array(MYSQLI ASSOC)): 


> 
</table></td> 


力 秘笈 心 法 


心 法 领悟 451: 获得 MySQLi 扩展 库 的 结果 集 。 
使 用 mysqli 类 中 的 query0 方 法 所 返回 的 对 象 来 调用 fetch_array0 方 法 ， 可 以 获得 查询 结果 集 ， 该 方法 的 语 
法 格式 如 下 : 


fetch_array ( [int resulttype] ) 

fetch_array0) 方 法 中 包含 一 个 可 省 参数 resulttype， 该 参数 用 于 指定 返回 结果 的 类 型 ， 其 参数 取 值 及 说 明 
如 下 : 

MYSQLI ASSOC: 指定 返回 结果 集 为 关联 数组 。 

MYSQLI NUM: 指定 结果 集 为 索引 数组 。 

MYSQLI BOTH: 指定 结果 集 既 包含 关联 数组 又 包含 索引 数组 。 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(3) 分 别 执行 index php 文件 和 index_1.php 文件 查看 结果 ， 如 图 93 和 图 9.4 所 示 。 
图 秘笈 心 法 


心 法 领悟 452: 使 用 函数 mysqli_error0 和 mysqli_ermo0 获 得 最 后 一 次 出 错 的 错误 信息 和 错误 号 。 

本 实例 使 用 函数 mysqli_connect_error0 和 mysqli connect_ermo0 来 获得 连接 数据 库 时 的 错误 信息 和 错误 号 ， 
那么 如 何 获得 MySQLi 扩展 库 在 操作 MySQL 数据 库 过 程 中 的 所 有 错误 信息 和 错误 号 呢 ? 这 里 可 以 使 用 函数 
mysqli_error0 和 mysqli_errno0 实 现 ， 其 中 函数 mysqli_error0 用 于 返回 操作 MySQL 数据 库 时 最 后 一 次 的 错误 信 
息 ， 其 语法 格式 如 下 : 

string mysqli_error ( mysqli link ) 

参数 link 为 函数 mysqli connect0 成 功 连接 MySQL 数据 库 的 连接 句柄 。 

mysqli_ermo0 用 于 返回 操作 MySQL 数据 库 时 最 后 一 次 的 错误 号 ， 其 语法 格式 如 下 : 

int mysqli_ermo ( mysqli link ) 

同样 ， 参 数 link 为 函数 mysqli_connect0 成 功 连接 MySQL 数据 库 的 连接 句柄 。 


| | 


实例 453 


图 实例 说 明 


-个 成 型 的 项 目 会 包含 很 多 数据 表 ， 并 且 表 之 间 可 能 存在 相互 关联 ， 本 实例 将 讲解 如 何 使 用 MySQLi 扩展 
库 执 行 多 表 之 间 的 关联 查询 。 运 行 本 实例 ， 如 图 9.5 所 示 ， 在 页 面 中 打印 出 学 生 的 学 号 、 姓 名 和 主要 科目 的 成 


绩 信息 。 
[| | 
0312315 刘 小 江 路 0 94 
0312316 会 胜 县 名 25 76 
W312317 黄 小 全 E3 Ey 四 
03123t2 李 小 林 76 加 
图 9.5 学 生成 绩 列 表 
图 关键 技术 


实现 本 实例 的 关键 技术 是 如 何 通过 主键 实现 多 表 之 间 的 连接 查询 ， 下 面 是 本 实例 实现 多 表 查 询 的 代码 : 


$sql=$conn->query("select * from tb_student, tb_score Where tb_studentid=tb_score.sid"); 

实现 多 表 之 间 的 查询 应 在 from 子 名 后 列 出 所 有 的 表 名 ,并 且 表 名 之 间 用 逗号 进行 分 割 。 同 时 应 在 where 关 
键 字 中 指明 多 表 之 间 的 连接 条 件 ， 例 如 本 实例 中 的 tb_student.id=tb_score.sid， 表 示 学 生 表 和 成 绩 表 之 间 通 过 学 
生 表 的 id 字段 和 成 绩 表 的 sid 字段 进行 连接 。 


图 设计 过 程 


(1) 建立 conn.php 文件 实现 与 MySQL 数据 库 之 间 的 连接 ， 代 码 如 下 : 
S$conn=new mysqli(“localhost”,"root”,”111”."db_database09"); // 建 立 与 MySQL 数据 库 的 连接 
Sconn->query("set names utf8"): // 设 置 字符 编码 


(2) 建立 index.php 文件 用 于 实现 多 表 之 间 的 查询 ， 如 果 学 生 表 和 成 绩 表 中 有 满足 条 件 的 记录 则 显示 这 些 
记录 ， 和 否则 提示 没有 相关 信息 ， 代 码 如 下 : 


<?php 
include_once("conn.php"); /| 包含 conn php 文件 
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$sql=$conn->query("select * from tb_student.tb_score where tb_student.id-=tb _score.sid"): /跨行 关联 查询 
S$info=$sql->fetch_array(MYSQLI_ASSOC): /获得 查询 结果 集 
if($info—=NULL){ // 未 查 到 结果 ， 将 给 出 提示 
echo " 暂 无 学 生 信息 
jelsef 
do{ 
> 
<t> 


<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sno];?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $infofywl:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[wy]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[sx]:?></div></td> 
</tr> 


<php 
}while( $info=$sql->fetch_array(MYSQLI ASSOC)): /通过 循环 打印 成 绩 信息 
} 


% 


图 秘笈 心 法 


心 法 领悟 453: 使 用 隐 式 连接 查询 实现 多 表 之 间 的 关联 查询 。 

实现 本 实例 所 采用 的 多 表 之 间 的 关联 查询 称 为 显示 关联 查询 ， 查 询 语句 如 下 所 示 : 

select * from tb_student,tb_score Where tb_student.id=tb_score.sid 

除了 使 用 上 述 显示 关联 查询 外 ， 还 可 以 使 用 内 连接 查询 方式 实现 多 表 之 间 的 隐 式 关联 查询 ， 如 本 实例 的 多 
表 连 接 查 询 可 以 更 改 成 如 下 形式 : 


Select * from tb_student inner join tb_score on tb_student.id=tb_score.sid 
上 述 内 连接 查询 中 ， 使 用 inner join 子 句 指定 要 连接 的 表 名 ， 使 用 on 子 句 指定 两 个 表 的 连接 条 件 ， 如 果 还 
有 其 他 查询 条 件 ， 可 以 指定 where 子 句 。 


[II 说明: 为 了 规范 数据 库 查询 技术 ， 隐 式 查询 方式 将 成 为 多 表 连 接 查询 的 主流 方式 。 


本 实现 内 存 的 回收 


图 实例 说 明 


为 了 有 效 利用 服务 器 的 内 存 空间 ， 在 获取 较 大 结果 集 时 ,一 旦 结束 操作 ， 则 有 必要 回收 集合 所 需要 的 内 存 ， 
由 于 MySQLi 技术 可 以 采用 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 所 以 与 之 对 应 的 内 存 回收 方式 也 有 两 种 ， 笔 者 
将 通过 本 实例 讲解 内 存 回收 机 制 在 项 目 开发 过 程 中 的 意义 和 使 用 方法 。 运 行 本 实例 ， 如 图 9.6 所 示 ， 图 中 为 某 
班级 学 生 主要 科目 成 绩 的 列表 ， 并 在 显示 完 该 班 成 绩 后 对 内 存 进行 了 回收 。 
| 


0312315 刘 小 华 3 加 34 
[ra EE 器 5 

[EE 黄 小 全 区 器 75 
EE EE 加 四 7 


图 9.6 学 生成 绩 列表 


转 关键 技术 


PHP 为 了 迎合 不 同 开发 习惯 的 程序 员 ， 在 MySQLi 扩展 技术 中 提供 了 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 
所 以 实现 内 存 回收 也 存在 与 之 对 应 的 两 种 方式 。 如 果 采 用 面向 过 程 的 编程 方式 可 以 通过 如 下 函数 实现 内 存 回收 : 


bool mysqli_close ( object link) 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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法 如 下 所 示 : 
header('content-type:text/html; charset=UTF-8); 
如 果 页 面 中 包含 规范 的 HTML 代码 ， 可 以 在 HTML 的 Meta 标记 中 设置 页 面 编码 ， 设 置 方法 如 下 所 示 : 
<meta http-equiv="content-type" content="text/html; charset=UTF-8" /> 
完成 对 PHP 文件 及 页 面 编 码 的 设置 后 ， 还 需要 设置 数据 库 编 


ed 大 型 回 长 度 人 整理 
码 ， 一 般 需 要 进行 两 处 设置 。 在 创建 数据 表 时 要 设置 字段 的 字符 Fe [Maem 司 克 [Er | 
编码 ， 其 设置 方法 如 图 9.8 所 示 。 图 9.8 设置 表 中 字段 的 字符 编码 


完成 上 述 设置 后 ， 一 般 还 需要 在 程序 中 采用 编码 方式 设置 数 
据 库 字符 集 ， 其 设置 方法 可 以 通过 SQL 语句 实现 ， 例 如 本 实例 通过 如 下 语句 设置 数据 库 字 符 集 为 utf-8。 
$conn->query("set names utf8"); 


由 注意 : 设置 数据 库 字符 编码 为 utf-8 时 ， 应 该 为 set names utf8 而 非 set names utf-8， 请 不 要 多 加 字符 “-”。 


实例 455 


图 实例 说 明 

在 本 实例 中 运用 mysqli 函数 库 中 的 函数 ,实现 用 户 登 录 的 功能 , 从 中 体会 数据 库 连 接 函 数 (mysqli_connect0) 
和 操作 函数 (mysqli_query0、mysqli_fetch_row) 的 应 用 。 运 行 本 实例 ， 当 输入 正确 的 用 户 名 和 密码 之 后 ， 将 弹 
出 如 图 9.9 所 示 的 页 面 。 


图 9.9 用 户 登 录 


力 关键 技术 


在 本 实例 中 运用 mysqli_connect0 函 数 连接 数据 库 ， 运 用 mysqli connect_ errorO 函 数 返回 错误 信息 ， 运 用 
Imysqli_fetch_rowO 函 数 获取 查询 结果 的 记录 数 ， 判 断 登 录用 户 是 否 正确 。 

(1) mysqli connectO 函 数 ， 建 立 与 MySQL 数据 库 服务 器 的 连接 ， 其 语法 如 下 : 

object mysqli_connect([string hostname [. string username [. string passwd [. string dbname [. int port [, string socket]]]]]) 

mysqli_connect 0 函数 的 参数 说 明 如 表 9.2 所 示 。 


表 9.2 mysqli_connect( 函 数 的 参数 说 明 
参数 说 明 
可 选 参数 ，MySQL 数据 库 服务 器 的 地 址 


| 
semame | 可 选 参数 ，MySQL 数据 库 的 用 户 名 
password | 可 选 参 数 ，MySQL 数据 库 的 用 户 密码 
| 
| 


hostname 


dbname 可 选 参数 ， 要 连接 的 数据 库 名 
port 可 选 参数 ，MySQL 数据 库 的 端口 号 


socket 可 选 参数 ， 用 于 指定 管道 端口 
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(2) mysqli_fetch rowO 函 数 ,根据 所 获取 的 记录 生成 数组 ， 如 果 没 有 更 多 记录 则 返回 NULL， 其 语法 如 下 : 
mixed mysqli_fetch_ row( mysqli result result ) 
参数 result 为 mysqli_query0 函 数 执行 查询 后 的 返回 值 。 


图 设计 过 程 
(1) 建 立 conn.php 文件 , 实现 与 MySQL 数据 库 之 间 的 连接 。 在 conn.php 文件 中 , 首先 使 用 mysqli_connectO 


函数 连接 db_database09 数据 库 ， 用 户 名 是 root， 密 码 为 111。 然 后 ， 通 过 mysqli_connect_error0 函 数 定义 错误 
信息 。 最 后 ， 通 过 mysqli_query0 函 数 设 置 数据 库 的 编码 格式 ， 其 代码 如 下 : 
<?php 


$conn=mysqli_connect("localhost","root","111","db_database09"); // 连 接 数 据 库 
if (mysqli connect ermo0) { 
printft" 连 接 失 败 : %sm", mysqli_connect_errorO): /返回 错误 信息 
exit0: 
} 
mysqli_query($conn,"set names utf8"); // 设 置 数据 库 编码 格式 
> 


| (2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登录 的 用 户 名 和 密码 提交 到 index_ok.php 文件 处 理 。 
(3) 创建 index_ok.php 文件 ， 获 取 表单 提交 的 用 户 名 和 密码 , 根据 mysqli_fetch_row0 函 数 的 返回 值 判断 登 
录 的 用 户 名 和 密码 是 否 正确 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 

include("conn/conn.php"); // 包 含 数据 库 连 接 文件 

if($_POST['user]!="" || $_POST['pass]!=""){ // 判 断 用 户 名 和 密码 是 否 正确 
$sql=mysqli query($conn,"select * from tb login where username=".$ POST['user]." and password=".$ POST['pass].""); 
Sinfo=mysqli_fetch_row($sql); /获取 查询 结果 
if($info—NULL) 


并 
echo "<script>alert( 登 录 失 败 ! ); window.location.href='index.php'</script>"; 
Yelsef 
echo "<script>alert( 登 录 成 功 ! ); window.location.href='index.php';</script>"; 
} 


} 
?> 


图 秘笈 心 法 


心 法 领悟 4355: mysqli_fetch_row0 函 数 的 应 用 。 
根据 mysqli_fetch_rowO 函 数 的 返回 值 不 但 可 以 判断 是 否 存在 查询 结果 ， 如 果 与 while 语句 结合 使 用 ， 还 可 
以 输出 查询 结果 中 的 数据 。 


图 实例 说 明 

在 本 实例 中 运用 mysqli 函数 库 中 的 mysqli_real connectO) - 漠 : _ 
函数 实现 与 MySQL 数据 库 的 连接 , 从 而 实现 用 户 注册 的 功能 ， “| es: Co 
并 且 介 绍 一 种 检测 SQL 语句 中 错误 的 方法 。 运行 本 实例 , 输入 ge | 


用 户 的 注册 信息 ， 如 果 用 户 输入 的 用 户 名 已 经 存在 ， 则 输出 用 
户 名 已 经 存在 的 提示 信息 ， 和 否则 提示 用 户 注册 成 功 ， 其 运行 结 
果 如 图 9.10 所 示 。 


图 9.10 用 户 注 册 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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ee gb2312"); // 设 置 数据 库 编码 格式 
(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 注册 信息 提交 到 index_ok.php 文件 进行 处 理 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 用 户 注册 信息 ， 首 先 ， 判 断 提交 的 用 户 名 是 否 被 占用 ， 如 果 
未 被 占用 ， 则 将 用 户 注册 信息 添加 到 tb_reg 表 中 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html: charset=gb2312" ): // 设 置 页 面 编 码 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
if($_POST['user]!="" || $_POST['pwd1]!="" ){ / 漳 断 输入 的 用 户 名 和 密码 是 否 为 空 
Scheck="select name from tb _reg where name=".S_POST[user]."": /定义 验证 用 户 名 是 否 被 占用 的 SQL 
Sresult=mysqli_query($conn,$check); /| 执行 查询 语句 
Sinfo=mysqli_fetch_row($result); /获取 查询 结果 
if($info!=NULD){ 
echo "<script>alert( 您 输入 的 用 户 名 已 经 存在 ! ); window.location.href='index.php';</script>"; 
Jelse{ 


$sql="insert into tb reg(name,pwd,email,address) 
values(".$_POST['user].™,".md5($_POST[pwd1]).",".$_POST['email].",".$_POST['address].")"; 
Sresult=mysqli_query($conn,$sql); 


echo mysqli_error($conn):; /返回 SQL 语句 中 的 错误 信息 
if(Sresult){ 

echo "<script>alert( 注 册 成 功 !); window.location href="index.php';</script>"; 
Jelse{ 


echo "<script>alert( 注 册 失 败 !); window.location.href='index.php';</script>"; 


图 秘笈 心 法 


心 法 领悟 436: 检测 SQL 语句 中 的 错误 。 
在 mysqli 函数 库 中 ， 可 以 通过 mysqli_error0 函 数 来 检测 程序 SQL 语句 中 的 错误 ， 以 帮助 我 们 及 时 地 发 现 
SQL 语句 中 的 问题 。 


图 实例 说 明 


在 前 面 的 实例 中 介绍 了 如 何 通 过 mysqli 函 数 库 中 的 函 
数 实现 用 户 注 册 和 登录 的 功能 ， 在 本 实例 中 将 介绍 如 何 通 
过 mysqli 函数 库 中 的 函数 完成 数据 的 浏览 操作 。 运行 本 实 
例 ， 将 循环 输出 数据 库 中 指定 数据 表 的 数据 ， 其 运行 结果 
如 图 9.11 所 示 。 


图 关键 技术 


在 本 实例 中 ， 获 取 查 询 结果 中 数据 应 用 的 是 mysqli_fetch_object0 函 数 ， 并 结合 while 语句 完成 其 返回 对 象 
中 数据 的 输出 。 

mysqli_fetch_object0 函 数 ， 返 回 一 个 由 执行 查询 后 生成 的 表 字 段 组 成 的 对 象 ， 其 语法 如 下 : 

mixed mysqli_fetch_object(object result) 

参数 result 为 mysqli_query0 函 数 执 行 查询 的 返回 值 。 

获取 返回 对 象 中 数据 的 格式 如 下 : 


图 9.11 浏览 注册 用 户 
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<?php echo Sobj->name: ?> 
其 中 $obj 为 返回 的 对 象 ，name 为 字段 名 称 。 


图 设计 过 程 


确 ， 


(1) 建立 conn.php 文件 实现 与 MySQL 数据 库 之 间 的 连接 。 

(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登录 信息 提交 到 index_ok.php 文件 进行 处 理 。 

(3) 创建 mdex_okphp 文件 ， 获 取 表 单 提交 的 用 户 登录 信息 ， 判 断 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 
则 将 登录 用 户 名 存储 到 SESSION 变量 中 ， 并 跳 转 到 main.php 文件 ， 其 代码 如 下 : 


<?php 

session_startO; /初始 化 session 变量 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include("conn/conn.php"): // 包 含 数据 库 连 接 文件 


if($_POST['user]!="" || $_POST['pass]!=""){ 


echo "<script>alert( 登 录 失败 ! )); window.location href=index.php'</script>"; 
Jelse{ 
$ SESSION['user|=$ POSTh'user; 
echo "<script>alert( 登 录 成 功 ! ); window.location href=main php';</script>"; 
} 
} 
> 


(4) 创建 main.php 文件 ， 连 接 数 据 库 类 ， 执 行 查询 语句 ， 应 用 mysqli_fetch_object0 函 数 和 while 语句 完成 


数据 库 中 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<Iphp 
Session_startO: 
include("conn/conn.php"); 
if($_SESSION['user]—true){ 


> 
/省 略 部 分 代码 
<2php 
$sql=mysqli_query($conn,"select name.email,address from tb_reg "); 
while(Sobj=mysqli_fetch_object(SsqD){ 
?> 


<t> 
<td height="22" align="center"><?php echo $obj->name:?></td> 
<td align="center"><?php echo substr($obj->email.0.20):?></td> 
<td align="center"><?php echo $obj->address:?></td> 
</t> 
php j 


?> 
/省 上 略 部 分 代码 
<?php 


jelsef 

echo "<script>alert(' 您 不 具备 访问 权限 ! 小 window.location href-'index.php':</script>": 
} 
> 


图 秘笈 心 法 


心 法 领悟 457: 返回 查询 结果 集中 的 数据 。 
返回 查询 结果 集中 的 数据 ， 不 但 可 以 使 用 mysqli_fetch_object0 函 数 ， 还 可 以 使 用 mysqli_fetch_arrayO、 


Imysqli_fetch_ assocO0 和 mysqli_fetch_row0 函 数 。 


通过 mysqli_fetch array0 函 数 返回 的 查询 结果 集 可 以 使 用 数字 索引 或 者 关联 索引 来 读 取 数据 ; 而 通过 


mysqli_fetch_assoc0 函 数 返 回 的 查询 结果 集 必须 使 用 关联 索引 来 获取 数据 ， 通 过 mysqli_fetch_row0 函 数 返 回 的 
查询 结果 集 必须 使 用 数字 索引 来 获取 数据 。 
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实例 458 


图 实例 说 明 


ET 


在 本 实例 中 应 用 mysqli 函数 库 中 的 函数 动态 地 对 数据 库 和 数据 表 进行 操作 ,统计 数据 表 中 的 字段 和 记录 数 ， 


并 且 循环 输出 数据 表 中 的 数据 ， 其 运行 结果 如 图 9. 


六 数据 旗 商 总 


首页 新 SR 市 | 


12 所 示 。 
搜索 


热 销 商 品 特价 专区 


sd 
使 用 帮助 


SSE5:[ EE 7 国 


该 坦 共 有 字 牙 3 个 ii 素 共 有 记录 : 务 


EE 


图 9.12 浏览 注册 用 户 


图 关键 技术 


(1) 统计 查询 结果 中 的 字段 数 应 用 的 是 mysqli_num fieldsO 函 数 ， 其 语法 如 下 : 


int mysqli num fields(mysqli_result result) 


参数 result 为 mysqli queryO0、mysqli_store_result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(2) 统计 查询 结果 中 的 记录 数 应 用 的 是 mysqli num rows 函数 ， 其 语法 如 下 : 


int mysqli_num rows(mysqli_result result) 


参数 result 为 mysqli queryO、mysqli_store_result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(3) 获取 数据 表 中 字段 信息 应 用 的 是 mysqli_fetch_fields0 函 数 。 它 返回 一 个 对 和 象 数 组 ， 该 数组 包含 某 表 字 


段 的 信息 ， 如 果 该 表 的 字段 为 定 ， 则 返回 FALSE,， 
array mysqli_ fetch fields(mysqli_result result) 
参数 result 为 mysqli_query0 函 数 的 返回 值 ， 返 


其 语法 如 下 : 


回 的 对 象 数组 可 以 调 上 


的 属性 如 表 9.5 所 示 。 


表 9.5 mysqli_fetch_fields(0) 函 数 返 回 的 对 象 数组 可 以 调用 的 属性 说 明 


属 性 说 了 明 

name 返回 字段 的 名 称 

orgname 返回 字段 的 原始 名 称 
table 返回 字段 所 属 的 表 名 
orgtable 返回 字段 所 属 的 原始 表 名 
def 返回 该 字段 的 默认 值 
max_length 返回 字段 的 最 大 宽度 
length 字段 的 宽度 
charsetnr 返回 字段 所 属 的 字符 集 
flags 返回 一 个 描述 字段 的 位 标记 
type 返回 字段 的 数据 类 型 
decimals 返回 字段 小 数 部 分 的 位 数 
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在 本 实例 中 只 是 应 用 name 属性 ， 获 取 数据 表 字 段 的 名 称 。 
图 设计 过 程 

在 本 实例 中 ， 创 建 index.php 文件 。 首 先 ， 创 建 form 表单 ， 将 要 访问 的 数据 库 和 数据 表 名 称 提交 到 本 页 。 
然后 ， 获 取 提 交 的 数据 库 、 数 据 表 名 称 ， 执 行 连接 操作 ， 连 接 成 功 后 ， 统 计数 据 表 中 字段 和 记录 的 总 数 。 最 后 ， 
循环 输出 指定 数据 表 中 的 数据 ， 其 关键 代码 如 下 : 

外 gosrkubmigcot 

$dbname=$ POST[dbnamel; 

$tbname=$ POST[tbname]; 

S$conn=mysqli_connect("localhost","root","111".Sdbname): 

这 mysqli connect ermo0) { 


printf(" 数 据 库 连 接 失 败 : %s\n", mysqli_connect_error0); 
exitO; 


. 

mysqli query($conn,"set names utf8"); 
Sresult=mysqli_query($conn,"select * from ".$tbname.""); 

echo "该 表 共 有 字段 &nbsp;".mysqli_num fields($result)."&nbsp; 个 !"; 
echo "该 表 共 有 记录 &nbsp;".mysqli_num rows(Sresulb)."&nbsp: 条 ， 

} 

?> 


<itd> 
</t> 
</table> 
<?php 
if($conn){ 
> 


<table width="550" bordercolor="#FFFFFF" bgcolor="#FFCC33"> 
<t> 
<?php 
for($i=0; $i<mysqli num_fields($result):Si++){ 
S$obj=mysqli_fetch_field($result); 
?> 
<td height="25" bgcolor="#FFFFFF" ><div align="center"><?php echo Sobj->name:?></div></td> 
<Iphp 
} 
?> 


< 
<?php 
$query = "select * from ".$tbname.""; 
$sql=mysqli_query($conn.Squery); 
$info=mysqli fetch array($sql); 
这 Sinfo 一 NULDJ{ 

echo " 暂 无 员工 信息 !"; 
Yelsef 

do{ 
> 
<t> 


hp 

for($i=0; Si<mysqli_num_fields(SsqD:SitH){f 

和 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[$il:?></div></td> 

<2php 

} 
3 

< 


}while($info=mysqli fetch array($sql): 
} 
mysqli_close(Sconn): 


> 
</table> 


<2php 
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图 设计 过 程 
(1) 建立 数据 库 及 数据 库 表 。 本 实例 中 将 数据 表 命 名 为 tb_admin， 其 创建 过 程 可 以 通过 phpMyAdmin 实现 。 
(2) 完成 数据 表 的 创建 后 ， 在 命令 提示 符 下 建立 视图 ， 创 建 视图 的 代码 如 下 


create view chkadmin as select name, pwd from tb_admin 
创建 的 视图 chkadmin 中 只 包含 name 和 pwd 两 个 字段 信息 ， 这 样 使 得 程序 的 其 他 字段 信息 不 可 见 ， 从 而 可 
以 有 效 提 高 程序 的 安全 性 。 
(3) 采 用 PHP 中 的 MySQL 函数 库 建立 与 MySQL 数据 库 的 连接 .首先 使 用 mysql_connect0 函 数 连接 MySQL 
数据 库 ， 然 后 使 用 函数 mysql_select_db0 选 择 数据 库 db_database09， 最 后 使 用 函数 mysql_query0 执 行 set names 
utf8 语句 来 设置 数据 库 的 编码 为 utf8 编码 ， 实 现 该 过 程 的 代码 如 下 : 


S$conn=mysql_connect(“localhost", "root”,"111"); /建立 与 MySQL 数据 库 的 连接 
mysql_select_db("db_database09".$Sconn); /选择 数据 库 
mysql_query("set names utf8"): /设置 数据 库 字 符 编码 
(4) 判断 用 户 是 否 单 击 了 “进入 ”按钮 ， 如 果 是 ， 则 通过 视图 chkadmin 对 用 户 身份 进行 验证 ， 该 过 程 的 
代码 如 下 : 
if($_POST[submit]!=""){ 
include_once("conn.php"); /包含 conn.php 文 件 
Sname=$_POST[name]; /接收 提交 的 用 户 名 
Spwd=$_POST[pwd]; // 接 收 提交 的 用 户 密码 
$sql=mysql_query("select * from chkadmin where name=". $name." and 
pwd=".$pwd.™",Sconn); /| 执行 查询 
Sinfo=mysql_fetch_array($sql); /返回 结果 集 
if($info—false){ /判断 用 户 名 和 密码 是 否 正确 
echo "<script>alert( 用 户 名 或 密码 输入 错误 !"):history.back0;</script>"; 
exit; 
Jelse{ 


echo "<br><div align=center> 登 录 成 功 !</div>"; // 如 果 正 确 则 提示 登录 成 功 
} 
} 


图 秘笈 心 法 


心 法 领悟 459: 使 用 视图 的 实际 意义 

视图 在 项 目 开发 过 程 中 具有 非常 重要 的 实际 意义 ， 主 要 表现 在 如 下 两 点 : 

使 用 视图 可 以 使 查询 更 加 简化 。 在 程序 编写 中 , 如果 所 要 执行 的 查询 较为 复杂 , 可 以 将 其 转化 为 视图 ， 
从 而 简化 查询 。 

使 用 视图 还 可 以 提高 程序 的 安全 性 。 如 果 只 想 让 用 户 访问 某 表 中 的 某 几 个 指定 的 字段 ， 可 以 创建 一 个 
只 包含 这 些 字段 的 视图 ， 而 不 用 将 整个 表 的 所 有 字段 的 访问 权限 都 分 配给 该 用 户 。 


.G@g 技巧 ， 虽然 不 使 用 视图 也 可 以 完成 对 数据 库 的 操作 ， 但 在 字段 歼 量 较 多 或 安全 性 要 求 较 高 的 模块 中 建议 通 
过 视图 完成 查询 ， 从 而 有 效 地 提高 程序 的 可 维护 性 和 安全 性 。 


实例 460 


力 实例 说 明 

通过 本 实例 主要 讲解 如 何 对 已 经 创建 完成 的 MySQL 视图 进行 修改 ， 在 制作 本 实例 时 ， 首 先 需要 在 数据 库 
中 创建 数据 表 也 _changeview， 其 结构 如 图 9.15 所 示 ， 然 后 创建 视图 userinfo, 该 视图 中 包含 tb_changeview 表 中 
所 有 字段 ， 完 成 上 述 操作 后 ， 使 用 alter view 语句 对 视图 进行 修改 。 
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3 
太志 


厂 usemame varcnar50 gb2312 chinese_c 


厂 ”waerpwd 。 warcnar50 gb2312_chinese_ei 


图 9.15 创建 表 changeview 


图 关键 技术 


在 MySQL 中 修改 视图 可 以 通过 alter view 语句 实现 ，alter view 语句 的 具体 使 用 说 明 如 下 : 

alter view [algorithm= {merge | temptable | undefined} ]view view_name [(column list)] as select_statement[with [cascaded | local] check option] 
参数 说 明 : 

algorithm: 该 参数 已 经 在 创建 视图 中 作 了 介绍 ， 这 里 不 再 袭 述 。 

view_name: 视图 的 名 称 。 

select_statement: SQL 语句 ， 用 于 限定 视图 。 


图 设计 过 程 
(1) 使 用 phpMyAdmin 创建 数据 库 及 数据 库 表 ， 本 实例 中 将 数据 表 命 名 为 tb_changeview。 
(2) 使 用 create view 语句 创建 视图 userinfo， 其 创建 代码 如 下 所 示 : 
create view userinfo as select * from tb_changeview 
(3) 使 用 select 语句 查询 视图 userinfo， 查 询 代码 如 下 所 示 : 
select * from userinfo 
查看 执行 结果 ， 可 以 发 现 tb_changeview 表 中 的 所 有 字段 都 一 一 列 出 ， 如 图 9.16 所 示 。 
(4) 下 面 开始 修改 视图 ， 要 求 修改 后 只 列 出 username 字段 ， 代 码 如 下 : 
alter View Userinfo as select * from tb_changeview 
查询 视图 userinfo， 从 结果 中 可 以 发 现 , 此 时 只 列 出 username 一 个 字段 ， 从 而 说 明 视图 修改 成 功 ， 


图 9.16 创建 新 视图 图 9.17 修改 视图 
< 注意 : 如 果 数 据 库 采用 utf-8 编码 ， 在 命令 提示 符 下 通过 select 语句 显示 查询 结果 时 会 出 现 中 文 乱 码 现象 。 


图 秘笈 心 法 


心 法 领悟 460: 在 phpMyAdmin 的 查询 窗口 中 创建 和 修改 视图 。 

在 实现 本 实例 时 ， 创 建 视图 的 过 程 是 在 Windows 系统 的 命令 提示 符 窗口 中 实现 的 ， 为 了 提高 开发 效率 、 简 
化 程序 开发 人 员 的 操作 ,MySQL 数据 库 的 创建 和 维护 过 程 一 般 在 MySQL 的 图 形 管理 工具 phpMyAdmin 中 进行 ， 
phpMyAdmin 为 MySQL 数据 库 提供 了 较为 完善 的 创建 、 维 护 及 备份 等 操作 。 同 样 ， 如 果 使 用 phpMyAdmin 的 
查询 窗口 也 可 以 执行 SQL 命令 ， 所 以 可 以 在 该 查询 窗口 中 创建 视图 ， 其 具体 创建 过 程 如 下 : 

(1) 打开 phpMyAdmin 管理 页 面 ， 并 选择 要 管理 的 数据 库 ， 单 击 如 图 9.18 所 示 的 “查询 窗口 ”按钮 来 打 
开 phpMyAdmin 的 查询 窗口 。 

(2) phpMyAdmin 的 查询 窗口 如 图 9.19 所 示 ， 可 以 在 该 窗口 中 输入 SQL 命令 来 实现 对 指定 数据 库 及 表 的 
查询 操作 。 例 如 在 该 查询 窗口 中 输入 创建 视图 的 SQL 命令 ， 然 后 单 击 图 中 的 “执行 ”按钮 即 可 成 功 地 实现 视图 
的 创建 操作 。 
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图 秘笈 心 法 

心 法 领悟 461: 在 phpMyAdmin 的 命令 窗口 中 删除 视图 。 

要 删除 指定 的 视图 , 可 以 在 phpMyAdmin 的 命令 窗口 中 实现 .首先 打开 phpMyAdmin 的 命令 窗口 , 如 图 9.22 
所 示 ， I 最 后 单 击 “ 执 行 ” 按 钮 即 可 成 功 删除 指定 的 视图 。 


Run SQL query/queries on serverlocahost 回 
[dmpviewtesview 


灰 不 从 窗口 外 桥头 此 音 询 【Deimiter [- ] F 在 此 再 次 显示 此 查询 
执行 


BE 


图 9.22 在 phpMyAdmin 的 命令 窗口 中 删除 祝 


实例 462 


图 实例 说 明 

在 项 目 开发 过 程 中 数据 表 中 可 能 有 很 多 字段 ， 但 某 个 模块 可 能 只 需要 其 中 的 几 个 。 为 了 提高 查询 速度 
和 简化 操作 ， 可 以 将 该 模块 需要 的 字段 单独 提取 出 来 放 在 某 个 视图 中 ， 例 如 本 实例 涉及 到 学 生 表 和 成 绩 表 ， 在 
建立 的 视图 中 只 含有 与 学 生成 绩 有 关 的 字段 ， 如 图 9.23 所 示 。 
例 ， 如 图 9.24 所 示 ， 图 中 查询 结果 显示 的 内 容 即 为 视图 中 所 有 字段 中 的 内 容 。 


=lol x 
th_sco 加 | 


视图 的 应 用 oves 


姓名 语文 成 缚 外 二 甩 广 |。 数学 成 线 
Eg 4 华 加 
0312316 全 星星 0 85 TB 
EE Ea 吏 可 再 
EE 于 下 可 而 
图 9.23 创建 视图 图 9.24 学 生成 绩 列表 


图 关键 技术 

本 实例 创建 的 视图 涉及 到 多 表 查 询 ， 这 说 明 多 个 表 之 间 可 以 通过 视图 来 组 合 为 一 个 整体 ， 这 样 对 视图 的 操 
作 就 相当 于 多 表 查 询 。 但 如 果 这 些 表 中 有 相同 的 字段 ， 必 须 按 如 下 方式 书写 重 名 的 字段 : 

表 名 1. 字 段 名 , 表 名 2. 字 段 名 …… 
力 设计 过 程 


(1) 创建 视图 scoreinfo， 通 过 该 视图 显示 学 生成 绩 信 息 ， 该 视图 的 创建 代码 如 下 所 示 : 


create view scoreinfo as select sno.sname.ywW.Wy.SX from tb student.tb_score where tb_student.id=tb_score.sid 


(2) 建立 数据 库 连接 文件 conn.php， 实 现 与 MySQL 数据 库 的 连接 ， 并 设置 数据 库 字 符 集 为 utf-8 编码 ， 代 
码 如 下 : 
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else 
set variable—PHP’; 


end 直 
insert into tb (name) values (variable); 


end; 

在 MySQL 中 ， 存 储 过 程 的 建立 以 关键 字 create procedure 开始 ， 后 面 紧 跟 存储 过 程 的 名 称 和 参数 。MySQL 
的 存储 过 程 名 称 不 区 分 大 小 写 ， 例 如 PROCE10 和 proce10 代 表 同 一 存储 过 程 名 。 存 储 过 程 名 不 能 与 MySQL 数 
据 库 中 的 内 建 函 数 重 名 。 

存储 过 程 的 参数 一 般 由 3 部 分 组 成 。 第 1 部 分 可 以 是 站 、onut 或 inout。in 表示 向 存储 过 程 中 传 入 参数 ，out 
表示 向 外 传 出 参数 ， inout 表示 定义 的 参数 可 传 入 存储 过 程 并 可 以 被 存储 过 程 修改 后 传 出 ， 存 储 过 程 默 认为 传 入 
参数 ， 所 以 参数 让 可 以 省 略 。 第 2 部 分 为 参数 名 。 第 3 部 分 为 参数 的 类 型 ， 该 类 型 为 MySQL 数据 库 中 所 有 可 
用 的 字段 类 型 ， 如 果 有 多 个 参数 ， 参 数 之 间 可 以 用 逗号 进行 分 隔 。 

MySQL 存储 过 程 的 语句 块 以 begin 开始 ， 以 end 结束 。 语 句 体 中 可 以 包含 变量 的 声明 、 控 制 语句 、SQL 查 
询 语句 等 。 由 于 存储 过 程 内 部 语句 要 以 分 号 结束 ， 所 以 在 定义 存储 过 程 前 应 将 语句 结束 标志 “;” 更 改 为 其 他 字 
符 ， 并 且 该 字符 应 该 在 存储 过 程 中 出 现 的 几率 较 低 ， 可 以 用 关键 字 delimiter 转换 ， 例 如 : 


mysql>delimiter // 


存储 过 程 创建 之 后 ， 可 用 如 下 语句 进行 删除 : 
drop procedure proc_name 
参数 proc_name 指 存 储 过 程 名 。 
图 设计 过 程 
MySQL 存储 过 程 是 在 命令 提示 符 下 创建 的 ， 所 以 首先 应 该 打开 “命令 提示 符 ” 窗 口 。 


(1) 进入 “命令 提示 符 ” 窗 口 后 ， 首 先 应 该 登录 MySQL 数据 库 服务 器 ， 在 命令 提示 符 下 输入 如 下 命令 : 
mysqlu 用 户 名 -用 户 密码 


(2) 更 改 语句 结束 符号 。 本 实例 将 语句 结束 符 更 改 为 “//”， 代 码 如 下 : 


delimiter // 
(3) 创建 存储 过 程 前 应 首先 选择 某 个 数据 库 ， 代 码 如 下 : 

use 数据 库 名 

(4) 创建 存储 过 程 。 

(5) 通过 call 语句 调用 存储 过 程 。 

秘笈 心 法 

心 法 领悟 463: 使 用 存储 过 程 的 优点 。 

加 ”使 用 存储 过 程 进行 项 目 开发 可 以 提高 程序 的 可 移植 性 。 在 存储 过 程 中 ， 可 以 编写 事务 处 理 逻 辑 ， 并 可 

以 被 其 他 程序 所 重用 。 
加 ”存储 过 程 可 以 节省 大 量 的 工作 ， 不 


需要 重复 执行 同样 的 逻辑 运算 。 


力 实例 说 明 


通过 本 实例 主要 讲解 如 何 使 用 MySQL 存储 过 程 实现 用 户 登录 身份 的 验证 。 运 行 本 实例 ， 如 图 9.25 所 示 ， 
在 图 中 登录 窗口 的 文本 框 中 输入 用 户 名 和 密码 ， 然 后 单 击 “ 登 录 ” 按 钮 ， 如 果 用 户 录入 的 用 户 名 和 密码 正确 ， 
则 会 将 页 面 定向 到 如 图 9.26 所 示 的 登录 成 功 提示 页 。 
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i | <I) 
> Er 二 
登 ， A 本 | 
富有 水 OM:O: dD Pa rum | ”| 
地 十 (B) | 剧 hapi/127.0.0 1jmRjo9jo0nejsucress， php Elba | 
国 | 
墟 成功 登 录 二 站 ! 
(中 199-2010 明日 IT 和 新闻 阴 ES | 
EE 图 mm 可 


图 9.25 用 户 登 录 窗口 图 9.26 登录 成 功 的 提示 信息 


图 关键 技术 


在 创建 本 实例 的 存储 过 程 中 ， 为 了 防止 结束 符 冲突 ， 首 先 使 用 delimiter 语句 将 MySQL 默认 的 结束 符 “;” 
更 改 为 “//”， 然 后 创建 存储 过 程 ， 其 创建 代码 如 图 9.27 所 示 。 


图 9.27 创建 用 户 登录 验证 的 存储 过 程 


创建 完成 上 述 存储 过 程 后 ， 在 程序 中 使 用 call 语句 调用 要 执行 的 存储 过 程 ， 本 实例 使 用 MySQLi 扩展 库 执 
行 存储 过 程 ， 其 实现 代码 如 下 所 示 : 

$sql = $mysqli->query("call pro_login(".$usemame.", ".$password.")"); 
图 设计 过 程 


(1) 通过 MySQLi 扩展 库 建 立 与 MySQL 数据 库 的 连接 , 并 设置 数据 库 字 符 集 为 utf-8, 实现 代码 如 下 所 示 : 
Smysqli=new mysqli(“localhost”,"root”,”"111”,"db_database09"); /建立 与 MySQL 数据 库 的 连接 
S$mysqli->query("set names utf8" / 设 A 为 utf-8 


(2) 建立 用 户 登 录 表单 ， 当 用 户 在 表单 中 录入 用 户 名 和 密码 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 通 过 如 下 代码 验证 
用 户 的 登录 信息 是 否 正确 : 


iffisset($_POST[usemame]) &é& trim($_POST['username"])!=") 1/ 判断 用 户 是 否 提交 了 表单 
{ 
require_once Db.php’; // 包 含 Db.php 文 件 
Susemame = trim($_POST['username’]): /获得 提交 的 用 户 名 
Spassword = trim($_POST[password]): /获得 提交 的 用 户 密码 
$sql = $mysqli->query("call pro_login(".$Susername.", ".$password.")"); 。 “”// 调 用 存储 过 程 ， 执 行 查 询 
Sinfo = $sql->fetch_array(MYSQLI_ASSOC); /获得 查询 第 一 条 记录 
这 Sinfo (= nulD){ // 判 读 是 否 为 null 值 
$_SESSION['loginUsemame] = $username: /| 将 用 户 名 保存 到 session 中 
echo ‘<script>window.location.href="success.php":</script>"; // 重 定向 到 success.php 页 面 


Jelse { 
echo ‘<div style="width:300px: height:30px: line-height:30px: border:1px solid #E59B04: background-color-#FCF2E0; color:#FF0000:"> 用 户 
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图 设计 过 程 


(1) 通过 PHP 预定 义 类 mysqli 实现 与 MySQL 数据 库 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli(“localhost","root",”111"."db_database09"): 
Sconn->query("set names utf8"); 


(2) 调用 存储 过 程 pro_reg 实现 将 用 户 录入 的 注册 信 息 保 存 到 数据 库 ， 代 码 如 下 : 
if($sql=$conn->query("call pro_reg(™. 9 ee , 
echo "<script>alert(' 用 户 注册 成 功 script>": 
jelsef 
echo "<script>alert( 用 户 注册 失败 !");</script>"; 


图 秘笈 心 法 
心 法 领悟 465: 使 用 PDO 数据 库 抽象 类 执行 存储 过 程 。 
实现 本 实例 时 ,使 用 MySQLi 扩展 库 执行 存储 过 程 ， 除 使 用 该 方法 外 ， 还 可 以 使 用 PDO 数据 库 抽象 类 执行 
过 程 ， 在 实现 本 实例 时 ， 可 以 将 保存 用 户 注册 信息 的 代码 进行 如 下 更 改 来 演示 使 用 PDO 技术 执行 MySQL 
过 程 的 方法 。 
S$db 和. new PDO('mysql:host=localhost;dbname=db_database09'. root', Toot’); // 实 例 PDO 类 ， 连 接 MySQL 数据 库 
$stmt = $db->prepare("call pro_reg(?, ?, ?, ?)"); // 建 立 查 询 的 预 处 理 句柄 
$stmt->bindParam(1, $_POST[mc]): / 骂 定 参数 
Sstmt->bindParam(2, $_POST[pwd]): 
S$stmt->bindParam(3, $_POST['email]): 
$stmt->bindParam(4, $ POST['addressT); 
Sstmt->execute(); /执行 查询 


[ga 说 明 : 使 用 PDO 连接 MySQL 数据 库 时 ， 和 连接 字 符 囊 mysql:host=localhost:dbname=db database09 中 内 容 的 
顺序 可 以 颠倒 。 


9.4 ”MySQL 触发 器 


触发 器 在 数据 库 系统 开发 过 程 中 具有 非常 重要 的 作用 ， 例 如 可 以 防止 有 害 数据 录入 数据 库 、 可 以 改变 或 取 
消 insert、update 和 delete 语句 的 执行 及 在 一 个 会 话 中 监听 数据 库 中 的 数据 的 改变 。 


实例 466 


图 实例 说 明 


如 果 用 户 打算 在 数据 库 中 通过 触发 器 实现 某 一 动作 的 监听 ， 那 么 首先 应 该 创建 触发 器 。 触 发 器 是 在 命令 提 
示 符 下 创建 的 ， 如 图 9.31 所 示 。 


图 9.31 触发 器 创建 过 程 
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力 关键 技术 


MySQL 数据 库 中 创建 触发 器 的 格式 如 下 : 
create trigger < 触发 器 名 称 > 

{ before | after} 

{insert | update | delete} 

on < 表 名 > 

for each row 

< 触发 器 SQL 语句 > 


参数 说 明 : 


create trigger < 触发 器 名 称 >: 创建 一 个 新 触发 器 ， 并 指定 触发 器 的 名 称 。 
{ before | after}: 用 于 指定 在 insert、update 或 delete 语句 执行 前 触发 还 是 在 语句 执行 后 触发 。 


on < 表 名 >: 用 于 指定 响应 该 触发 器 的 表 名 。 


for each row: 触发 器 的 执行 间隔 。 for each row 通知 触发 器 每 隔 一 行 执行 一 次 动作 , 而 不 是 对 整个 表 执 行 一 次 。 


< 触发 器 SQL 语句 >: 触发 器 要 执行 的 SQL 语句 。 
图 设计 过 程 


(1) 在 命令 提示 符 下 创建 数据 表 tb_test， 代 码 如 下 : 
create table tb_test(t_id varchar(20),t_name varchar(20)) 
(2) 将 换行 标记 转换 为 “//”， 代 码 如 下 : 


delimiter // 


(3) 创建 触发 器 ， 实 现 无 论 用 户 向 表 tb_test 添加 什么 数据 都 使 字段 t_name 的 内 容 为 “mrsoft”， 代 码 如 下 : 


create trigger test tri 
before insert on tb_test 
for each row 
set new.t_name="mrsoft’ 
(4) 向 表 tb_test 中 添加 一 条 记录 ， 并 查看 结果 ， 代 码 如 下 : 
insert into tb_test(t_id,t_name) values(mr0001,'1239// 
select * from tb_test 


以 答 心 法 
心 法 领悟 466: 触发 器 中 执行 多 条 SQL 语句 。 


如 果 该 触发 器 要 执行 多 条 SQL 语句 ， 要 将 多 条 语句 放 在 begin..….end 块 中 。 


力 实例 说 明 


在 MySQL 数据 库 中 创建 触发 器 前 应 先 查 看 数据 库 中 的 触 
发 器 ， 这 样 既 可 以 使 开发 人 员 对 指定 的 数据 库 中 的 所 有 触发 器 
及 其 功能 有 一 个 直观 的 把 握 ， 而 且 可 以 避免 创建 同名 或 类 似 功 


获取 数据 库 利 的 项 发 加 
明日 科技 


能 的 触发 器 。 运 行 本 实例 ， 如 图 9.32 所 示 ， 首 先 在 图 中 的 文本 3 


框 中 输入 要 查看 触发 器 的 数据 库 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， [Le 


请 输入 数据 库 的 名 称 : db_dstsbase09 | 查看 
动 及 表 名 | 触 作 事件 | 时 间 可 攻 时 扩 生 959 名 
htest | TIEEET | EEFONE Set a ames erst 


即 可 将 该 数据 库 中 所 有 触发 器 的 详细 信息 显示 出 来 。 
图 关键 技术 


查看 MySQL 数据 库 中 触发 器 的 详细 信息 ， 可 以 通过 如 下 语句 实现 : 


图 9.32 查看 触发 器 
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删除 相关 id 的 工作 后 ， 还 没 来 得 及 删除 学 生 信息 表 中 该 学 生 的 信息 时 就 发 生 停电 等 意外 ， 则 再 重新 查找 该 学 生 
的 成 绩 时 是 无 法 查找 到 的 。 

本 实例 将 采用 事务 处 理 方式 ， 对 学 生 信息 表 和 学 生成 绩 表 中 的 数据 进行 删除 。 运 行 本 实例 ， 学 生 信息 及 学 
生成 绩 信息 分 别 如 图 9.33 和 图 9.34 所 示 。 当 删除 图 9.33 中 的 学 生 信息 后 ， 查 看 学 生成 绩 信息 时 可 以 发 现 ， 与 
该 学 生 对 应 的 成 绩 也 被 全 部 删除 。 


学 生成 续 管 理 系统 


一 本 


TB 


图 9.33 查看 学 生 信息 图 9.34 查看 学 生成 绩 


力 关键 技术 


事务 的 处 理 可 以 通过 PHP 的 预定 义 类 mysqli 的 以 下 方法 实现 。 

autocommit(boolean): 该 方法 用 于 限定 查询 结果 是 否 自动 提交 ， 如 果 参 数 为 true 则 自动 提交 ， 如 果 参 数 为 
false 则 关闭 自动 提交 。MySQL 数据 库 默 认为 自动 提交 

Iollback0: 利用 mysqli 类 中 的 该 方法 可 以 实现 事务 的 回 滚 。 

commit(): 利用 该 方法 可 以 实现 提交 所 有 查询 。 


图 设计 过 程 
(1) 建立 数据 库 及 数据 表 并 实现 与 数据 的 连接 了， 代码 如 下 : 


Sconn=new mysqli(“localhost","root","111","db_database09"); 
Sconn->query("set names utf8"); 
(2) 显示 所 有 学 生 的 基本 信息 ， 代 码 如 下 : 
<?php 
include once("conn.php"); 
$sql=$conn->query("select * from tb_stu"); 
S$info=$sql- se re 
if($info=—=NULL) 
echo 半生 信 息 v" 
Jelse{ 
do: 


?> 
<t> 
<td eh "25" ee oy align=" et echo Sl <div></td> 


<td bgcolor="#FFFFFF"><div align="center"><a href="javascript:if(window. 全 二 全 个 定 删 除 该 学 生 信息 
么 ?==trmue) {window.location.href='delete.php?id=<?php echo Sinfo[id]:?>";}"> 删 除 </a></div></td> 
</tr> 


hp 
}while($info=$sql->fetch_array(MYSQLI ASSOO)); 


> 
在 实现 该 模块 功能 时 ， 可 以 利用 JavaScript 实现 该 页 与 delete php 页 面 的 信息 传递 ， 代 码 如 下 : 
<a hre 全 "javascriptifwindow.confirm(' 确 定 删 除 该 学 生 信息 么 2) 一 tme){window.location hrefE-'delete php?id=<?php echo Sinfo[id]:?>':} "> 删除 </a> 
window 对 象 的 confirm0 方 法 用 于 弹出 一 个 对 话 框 ， 提 示 用 户 是 否 真正 删除 某 学 生 的 所 有 信息 。 
(3) 利用 事务 处 理 机 制 对 学 生 的 基本 信息 进行 删除 ， 代 码 如 下 : 
Sid-$_GET[id]; 
include_once("conn.php"); 
Sconn->autocommit(false): 
if(!$conn->query("delete from tb_sco where id=".$id.™){ 
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$conn->rollback(); 


if(!$conn->query("delete from tb stu where id=".$id.™"){ 
Sconn->rollbackO; 
} 
Sconn->commit(); 
Sconn->autocommit(true); 
echo "<script>window.location.href~'index.php':</script>"; 


图 秘笈 心 法 
心 法 领悟 468: 使 用 PDO 数据 库 抽象 类 执行 批 处 理事 务 。 


本 实例 使 用 MySQLi 扩展 库 实 现 对 MySQL 数据 库 事务 的 处 理 , 而 使 用 PDO 数据 库 抽 象 类 同样 可 以 实现 此 
功能 ， 其 示例 代码 如 下 所 示 : 


ty 
$db = new PDO(mysqlhost=localhostxdbname=db_database09' root, root: // 实 例 PDO 类 ， 连 接 MySQL 数据 库 
$db->beginTransaction(); /开启 事务 
$db->query($sql1); /执行 查询 1 
S$db->query($sql2); /执行 查询 2 
$db->commit(); /提交 查询 
} catch ee So { 
>rollBackO); // 事 务 回 滚 


ee Se->getMessage(); 


} 

上 述 代码 中 ， 首 先 使 用 new 关键 字 对 PDO 类 进行 实例 化 并 返回 PDO 对 象 ， 并 使 用 PDO 对 象 的 
beginTransaction() 方 法 开启 事务 ， 然 后 执行 多 条 查询 语句 ， 最 后 使 用 PDO 对 象 的 commit0 方 法 提交 事务 。 在 上 
述 操作 中 使 用 try.….catch 语句 判断 是 否 发 生 了 异常 ， 如 果 是 则 调用 PDO 对 和 象 的 rollBack0 方 法 对 事务 进行 回 深 。 


y | 
S | 7 
i en 
图 实例 说 明 
在 实现 银行 转账 过 程 中 ， 发 生意 外 是 在 所 难免 的 ， 为 了 避免 因 意外 而 造成 不 必要 的 损失 ， 在 银行 转账 时 经 


常 使 用 事务 处 理 方式 。 运 行 本 实例 ， 如 图 9.35 所 示 ， 在 图 中 的 文本 框 中 输入 要 转 给 B 账户 的 金额 后 ， 单 击 “ 转 
账 ” 按 钮 即 可 实现 转账 。 


图 9.35 银行 转账 
图 关键 技术 
本 实例 的 关键 技术 是 如 何 应 用 PHP 的 事务 处 理 机 制 处 理 转 账 过 程 中 可 能 遇 到 的 意外 。 应 用 事务 实现 转账 的 
代码 如 下 : 
S$tob=$_POST[tob]: // 接 收 提交 的 转账 金额 
include_once("conn.php"): // 包 含 数据 库 连 接 文 件 conn.php 
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$conn->autocommit(false): /取消 查询 自动 提交 


if(!$conn->query("update tb_zy set money=money-".$tob." where flag=’mrsoft")){ / 碱 少 指定 账户 所 要 转账 的 金额 
$conn->rollbackO; /如 果 失 败 则 事务 回 滚 

} 

if(!$conn->query("update tb_zy set money=money+".Stob." where flag=mr"™"){ /| 增加 指定 账户 所 要 的 转账 金额 
$conn->rollbackO; /如 果 失 败 则 事务 回 滚 

} 

$conn->commit(); /提交 查询 

$conn->autocommit(true); /恢复 查询 自动 提交 

echo "<script>window .location href='index.php';</script>"; // 重 定向 到 首页 


首先 调用 mysqli 类 的 autocommit0 方 法 关闭 数据 库 的 自动 提交 ， 然 后 减少 A 账户 一 定数 量 的 金额 并 判断 查 
询 是 否 顺 利 执行 ， 如 果 在 此 过 程 中 发 生意 外 ， 则 通过 调用 mysqli 类 的 rollback0 方 法 回 滨 ， 不 做 任何 处 理 ， 反 之 
为 B 账 户 增加 相同 的 金额 。 最 后 通过 调用 mysqli 类 的 commit0 方 法 提交 查询 ， 实 现 转账 。 

图 设计 过 程 


(1) 利用 MySQLi 扩展 技术 实现 与 MySQL 数据 库 的 连接 ， 代 码 如 下 : 
Seconn=new mysqli(localhost""root","111","db_database09"); /建立 与 MySQL 数据 库 的 连接 


$conn->query("set names utfs /设置 数据 库 字 符 集 编码 为 utf-8 
(2) 查询 A 账户 与 B 账户 的 现 有 金额 并 在 页 面 中 显示 ， 代 码 如 下 : 
include_once("conn.php"); // 包 含 数据 库 连 接 文件 conn.php 


$sql=$conn->query("select * from tb_zy where flag='mrsoft"); /查询 mrsoft 用 户 的 信息 
Sinfo=$sql->fetch_array(MYSQLI ASSOC); 

$sqll=$conn->query("select * from tb_zy where flag="mr"):; /查询 mr 用 户 的 信息 
Sinfol=$sqll->fetch_array(MYSQLI ASSOC); 


(3) 实现 转账 。 该 部 分 的 关键 代码 已 经 在 关键 技术 中 给 出 ， 这 里 不 再 歼 述 。 
图 秘笈 心 法 


心 法 领悟 469: 使 用 MySQLi 扩展 库 管 理 MySQL 数据 库 事务 时 ， 需 要 关闭 事务 的 自动 提交 。 

默认 情况 下 使 用 MySQLi 扩展 库 管理 MySQL 数据 库 时 ， 事 务 是 自动 提交 的 ， 所 以 在 对 事务 管理 时 首先 需 
要 关闭 事务 的 自动 提交 ， 其 方法 如 下 : 

Smysqli->autocommit(false); 

从 上 述 代 码 可 知 , 通过 调用 mysqli 类 的 autocommit0 方 法 ， 并 为 其 参数 指定 FALSE 值 即 可 关闭 事务 的 自动 
提交 。 同 理 ， 如 果 为 该 方法 的 参数 指定 TRUE 值 则 可 以 恢复 事务 的 自动 提交 功能 。 
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10.1 连接 数据 库 


SQL Server 是 Microsoft 公司 开发 的 数据 库 产 品 。 随 着 SQL Server 2005 的 诞生 ， 越 来 越 多 的 企业 开始 使 用 
SQL Server， 下 面 将 通过 具体 实例 讲解 PHP 连接 SQL Server 数据 库 的 方法 。 


SQL Server 数据 库 高 级 
起 呆 指数 商机 机 机 


图 实例 说 明 


本 实例 通过 ADO 方式 连接 SQL Server 数据 库 ， 运 行 本 实例 ， 如 果 出 现 如 图 10.1 所 示 的 用 户 信息 页 面 ， 说 


明 数 据 库 连 接 成 功 。 


AAOOF 
各 得 SGt s serverm 


二 


图 10.1 ADO 方式 连接 SQL Server 数据 库 


图 关键 技术 

PHP 通过 预定 义 类 com 来 使 用 ADO 方法 操作 数据 库 ， 该 类 的 详细 说 明 如 下 : 

string com::com( string module_name |, string server_name [, int codepage]]) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 。 

codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP_MACCP、 CP_OEMCP、 CP_SYMBOL、 CP_THREAD_ACP、 CP_UTF7 和 CP_UTF8。 

本 实例 与 SQL Server 建立 连接 的 代码 如 下 : 

$conn = new com("adodb. 


connection"); 
$connstr = "provider = sqloledb;data source=PC-201006101638;uid=sa;pwd=;database=db_database10"; 
$conn -> open($connstr); 


图 设计 过 程 
(1) 在 SQL Server 中 创建 数据 库 及 数据 表 用 于 连接 测试 。 
(2) 连接 SQL Server 数据 库 ， 建 立 记录 集 ， 通 过 while 语句 完成 用 户 信息 的 输出 ， 代 码 如 下 : 


<?php 

if($_CET[idl =— "1){ 
$sql = "select * from tb_demo01"; 
S$rs = new com("adodb.recordset"); 
S$rs -> open($sql,$conn,1,1); 
if($rs -> eof || $rs -> bof){ 

echo " 暂 无 用 户 注册 信息 "; 

Jelse{ 


<tr> 
<td align="center"> 用 户 名 </td> 
<td align="center"> 密 &nbsp;&nbsp: 码 </td> 
</tr> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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参数 说 明 : 

string query: SQL 语句 。 

link_identifier: 连接 标识 。 

(3) mssql_fetch_row0 函 数 ， 取 得 一 行 数据 ， 保 存 于 数组 中 ， 其 语法 如 下 : 


array mssql_fetch_row ( resource result ) 

参数 说 明 : 

resource result: 结果 集 。 

本 实例 与 SQL Server 建立 连接 的 代码 如 下 : 

$conn = mssql_connect("localhost","sa","") or die ("Connect MySQL False ); 
mssql_select_db("db_database10",$conn); 


图 设计 过 程 


在 本 实例 中 ， 通 过 mssql_connect0 函 数 连 接 SQL Server， 应 用 mssql_query0 函 数 执行 查询 语句 ， 应 用 


mssql_fetch_row0 函 数 和 while 语句 完成 用 户 信息 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 
$conn = mssql_connect ( "localhost", "sa”, "" ) or die ( "Connect SQL Server False" ); /连接 SQL Server 服务 器 
mssql_select_db ( "db_database10", $conn ); // 和 连接 db_database10 数据 库 
if ($_GET [lid] = "1) { 
?> 
<?php 
if($rs = mssql_query("select * from tb_demo01"){ // 如 果 返 回 结果 集 
while($rst = mssql_fetch_row($rs)){ /循环 输出 结果 集 
?> 
<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[0];?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[1]:?></td> 
<?php 
} 
Jelse{ 
echo "<script>alert( 数 据 表 存在 问题 );</script>"; 
} 
?> 
秘笈 心 法 


心 法 领悟 471: 如 何 检测 PHP 是 否 支 持 SQL Server 数据 库 。 
编写 脚本 文件 ， 输 入 如 下 代码 : 


<?php 
echo phpinfo0; 


经 下 浏览 器 运行 本 文件 ， 如 果 网 页 中 显示 mssql 内 容 ， 表 示 PHP 支持 SQL Server 数据 库 。 
如 果 用 户 使 用 的 SQL Server 数据 库 是 2000 版 本 ， 可 能 会 出 现 unable connect server:localhost 错误 ，i 

种 错误 的 原因 一 般 分 为 两 种 情况 : 
(1) 代码 存在 错误 。 检 查 SQL Server 服务 管理 器 是 否 处 于 正在 运行 的 状态 。 


(2) 系统 可 能 缺少 ntwdblib.dll 文件 。 用 户 可 以 手动 下 载 ntwdblib.dll-2000.80.2039.0 文件 ， 将 此 文件 复制 
到 Apache\bin 文件 夹 和 php\bin 文件 夹 下 ,然后 重启 SQL Server 服务 器 和 Apache 服务 器 即 可 。 也 可 为 SQL Server 


打上 sp4 补丁 ， 然 后 重启 服务 器 。 


10.2 操作 数据 库 


SQL Server 数据 库 与 MySQL 数据 库 虽 然 都 是 存储 信息 的 载体 ， 但 是 在 操作 方法 与 函数 上 略 有 不 同 。 本 节 
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将 具体 讲述 对 SQL Server 数据 库 的 相关 操作 。 


趣味 指数: 请 评 南 计 


力 实例 说 明 

在 进行 网 站 开发 过 程 中 ， 经 常用 到 对 指定 时 间 段 的 信息 检索 ， 例 如 ， 检 索 指定 时 间 段 内 有 哪些 PHP 图 书 出 
版 等 。 运 行 本 实例 ， 当 单 击 “ 信 息 检索 ” 超 链接 时 ， 将 显示 2009 年 ~2010 年 明日 科技 编写 的 所 有 PHP 图 书 ， 其 
运行 效果 如 图 10.3 所 示 。 


过 起 AD 方式 委 络 写 的 问 的 信和 


图 书 To 图 书香 称 图 书 昼 格 出 版 社 
1 《PRE 范 例 宝 典 》 从 人 民 邮电 出 版 社 
2 《PAP 实战 字 央 》 天 清华 大 学 出 版 社 
3 《ERE 同 络 编程 5 未 财 大 学 出 贱 社 


图 10.3 通过 ADO 实现 指定 时 间 段 的 信息 检索 


力 关键 技术 


本 实例 通过 ADO 操作 SQL Server 数据 库 ， 执 行 指定 时 间 段 内 的 信息 查询 操作 ， 其 信息 检索 的 SQL 语句 代 


人 码 如 下 : 
$sql = "select id,bname,price,pub from tb_demo03 where date>="2009-01-01’ and date<='2010-12-31”; 


图 设计 过 程 

创建 index.php 文件 , 首先 通过 ADO 连接 SQL Server 数据 库 , 然后 建立 记录 集 , 实现 用 户 信 息 的 循环 输出 ， 
其 关键 代码 如 下 : 

<?php 


$conn = new com ( "adodb.connection" ); 
$connstr = "provider = sqloledb;data source=PC-201006101638;uid=sa;pwd=;database=db_database10"; /ADO 连接 数据 库 


$conn->open ( $connstr ); 
if ($_GET [lid] = "1") { 
$sql = "select id,bname,price,pub from tb_demo03 where date>='2009-01-01 and date<='2010-12-31”; 
$rs = new com ( "adodb.recordset" ); 
S$rs->open ( $sql, $conn ); 
if ($rs->eof | $rs->bof) { 
echo "数据 库 暂 无 信息 "; 
}else { 
?> 


<tr> 
<td align="center”> 图 书 ID</td> 
<td align="center"> 图 书 名 称 </td> 
<td align="center"> 图 书 价格 </td> 
<td align="center"> 出 版 社 </td> 


<?php 
while (! $rs->eof ) { 
?> 


<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8,, $rs->fields (id )->value ); ?></td> 

<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8,, $rs->fields ( bname )->value ); ?2></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( gbk, ‘utf-8', $rs->fields ( price )->value ); ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ('gbk, ‘utf-8', $rs->fields ( pub )->value ); ?></td> 
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Srs -> movenext; 


?> 


图 秘笈 心 法 


心 法 领悟 472: 解决 页 面 乱码 问题 。 
由 于 在 SQL Server 中 使 用 的 编码 格式 是 gbk， 而 页 面 中 的 编码 格式 为 uft-8， 所 以 需 使 用 转 码 函数 iconv0 对 
输出 结果 进行 转 码 ， 和 否则 将 输出 乱码 。 


实例 473 趣味 指数 : 伍 侠 合 窗 


图 实例 说 明 


在 实际 开发 中 ， 很 多 程序 都 会 涉及 到 对 信息 的 检索 。 运 行 本 实例 ， 输 入 商品 ID， 单 击 “ 检 索 ” 按 钮 ， 将 查 
找 出 匹配 的 商品 信息 ， 并 且 对 商品 名 称 描 红 显 示 ， 运 行 结果 如 图 10.4 所 示 。 


地 让 ADO 方 式 实现 二 时间 民 的 全 入 亲 


ba 南口 名 称 而 品 价格 
由 液晶 电视 0 


图 10.4 商品 信息 的 检索 


力 关键 技术 


本 实例 通过 mssql_connect0 函 数 连 接 SQL Server 服务 器 ， 通 过 mssql_select_db0 函数 连接 db_database10 数 
据 库 ， 通 过 mssql_query0 函数 执行 查询 语句 ， 通 过 mssql_fetch_row0 函 数 获取 查询 结果 中 的 数据 ， 其 关键 代码 


如 下 : 
<?php 
$conn = mssql_connect ( "localhost", "sa”, "" ) or die ( "Connect SQL Server False"” ); /连接 数据 库 服 务 器 
mssql_select_db ( "db_database10", $conn ) or die ( "Connect Database False" ); /连接 数据 库 
if ($_POST [sub]) { /1 判断 提交 按钮 是 于 为 空 
if ($_POST [text] == "||$_POST [text] 一 "输入 商品 ID") { // 和 如 果 提 交 ID 值 为 室 ， 则 给 出 提示 信息 
echo "<script>alert( 请 输入 查询 关键 字 );</script>"; 
}else{ 
S$rs = mssql_query ( "select * from tb_demo04 where id=" . $_POST [text] ); / 慌 行 查询 语句 
?> 
设计 过 程 
(1) 在 index.php 文件 中 ， 首 先 创建 form 表单 ， 将 商品 的 ID 值 提交 到 本 页 ， 其 代码 如 下 : 
<form action="" method="post"> 


<input class="one” type="text” name="text” value=" 鹏 入 砚 旬 ID" size="15" onfocus="this.value="”” /> 
<input class="hwo” type="submit” name="sub” value="@nbsp;”" /> 
</form> 


(2) 在 index.php 文件 中 ， 通 过 mssql_connect0 函 数 连接 SQL Server， 根 据 form 表单 中 提交 的 ID 值 执行 


查询 语句 ， 并 循环 输出 查询 结果 ， 代 码 如 下 : 
<2 
a "sa", ™” ) or die ( "Connect SQL Server False” ); 
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Lselect_db ( "db_database10", $conn ) or die ( "Connect Database False" ); 
if ($_POST [sub]) { 
证 ($_POST [text] == "上 $_POST [text] 一 "输入 商品 ID") { 
echo "<script>alert( 请 输入 查询 关键 字 );</script>"; 
jelse{ 
Srs = mssql_query ( "select * from tb_demo04 where id=" .$_POST [text] ); 
全 


<tr> 
<td align="center"> 商 品 ID</td> 
<td align="center"> 商 品名 称 </td> 
<td align="center"> 商 品 价格 </td> 
<td align="center"> 商 品类 型 </td> 
</tr> 
<?php 
$rst = mssql_fetch_row ( $rs ); 
?> 
<tr> 
<td align="center” bgcolor="#F FFFFF"><?php echo S$rst [0]; ?></td> 
<td ><font size="+1" color="#FF0000"><b><?php echo iconv ( gbk'，utf-8, $rst [1] );?></b></font></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo iconv (‘gbk', ‘utf-8', $rst [2] ); ?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo iconv(gbk','utf-8',$rst[3]);?></td> 
<?php 
} 
} 
Ws 


秘笈 心 法 

心 法 领悟 473: 判断 连接 SQL Server 数据 库 是 否 成 功 的 方法 。 

判断 连接 数据 库 是 否 成 功 的 方法 有 很 多 。 例 如 ， 可 以 应 用 if0 条 件 语句 对 函数 进行 判断 。 但 是 笔者 喜欢 用 
or die( 方 法 实现 对 目标 函数 的 检测 ， 其 最 大 的 优点 是 书写 简单 、 逻 辑 清晰 、 代 码 量 小 。 


实例 474 


图 实例 说 明 


在 使 用 SQL Server 数据 库 时 ， 很 多 时 候 需 要 获取 指定 的 第 n 条 数据 信息 。 用 MySQL 数据 库 实 现 此 功能 非 
常 简单 。 那 么 如 何在 SQL Server 数据 库 中 实现 相同 的 功能 呢 ? 下 面 就 来 向 读者 讲解 实现 此 功能 的 具体 方法 。 运 
行 本 实例 ， 在 图 10.5 所 示 的 文本 框 中 输入 指定 的 ID 值 ， 单 击 “ 确 定 ” 按 钮 ， 将 输出 如 图 10.6 所 示 的 内 容 。 


请 内 入 续 py TE rr 
获取 指定 位 置 的 加 书信 息 
1 《PHP 开发 实战 训 典 》 Sa w 
名 《PHP 标 准 教程 》 CB 
3 《PHP 网 络 纳 种 宝 其 73 
4 《PNP 范例 宝 虹 3 元 
9 《PHP 范 合 手册 》 8 元 《PKP 网 结 娟 程 宝典 》 7? 玩 2010/ 八 月 /31 0: 00 
10.5 数据库 信息 图 10.6 获取 指定 位 置 的 图 书信 息 


图 关键 技术 


本 实例 主要 应 用 mssql_data_seek0 函 数 。mssql_data_seek(0 函 数 将 指定 的 结果 标识 所 关联 的 SQL Server 结果 


634 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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取得 履 据 中 天 十 的 字段 名 村 | 


请 杭 入 雪 字 BB 


取得 阔 所 中常 定 的 字段 名 称 
《PRP 开 发 实战 宝 咎 》 14 元 2010/AA /3 to0 
了 BB 


3 《PRP 标 准 教 址 } ?9 元 2010/ 八 月 /31 0:00 

了 《PEP 网 络 护 条 宝典 ? 玩 20L07 信 月 /131 G00 

4 《PhP 范例 宝典 } 9 元 200 入 有 /3 to0 

了 《PhP 范 合乎 册 人 元 20t0/ 入 月 /30 0: 00 tate date marerime 4 
图 10.7 显示 数据 库 中 数据 图 10.8 获取 字段 信息 


图 关键 技术 
mssql_fetch_field0 函数 ， 从 结果 集中 获取 列 信息 并 作为 对 象 返 回 ， 其 语法 如 下 : 


object mssql_fetch_field ( resource result [, int field_offset] ) 


对 象 的 属性 如 表 10.1 所 示 。 


表 10.1 mssql_fetch_field() 函 数 返 回 的 对 象 的 属性 


属 性 说 了 明 
name 列 名 
column_source 具体 的 列 名 
max_length 该 列 最 大 长 度 
numeric 1， 如 果 该 列 是 numeric 
type 该 列 的 类 型 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 ， 其 代码 如 下 : 
<?php 
$conn = mssql_connect("localhost","sa","") or die ("连接 SQL Server 时 发 生 错误 "); 
mssql_select_db("db_database10",$conn) or die ("连接 数据 库 发 生 错误 "); 
?> 


(2) 新 建 index.php 文件 ， 首 先 ， 创 建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 ， 对 表单 中 提交 的 定 
位 查询 数据 进行 判断 ， 判 断 其 值 是 否 为 空 、 提 交 的 数据 是 否 是 数字 、 提 交 的 值 是 否 超出 范围 ， 如 果 完 全 符合 条 
件 ， 则 应 用 mssql_fetch_field0 函 数 获 取 表单 中 指定 字段 的 数据 ;如果 判 断 结果 不 符合 要 求 ， 则 给 出 相应 的 提示 
信息 ， 并 且 循环 输出 数据 表 中 所 有 的 数据 ， 其 关键 代码 如 下 : 


<?php 
include_once ("conn.php"); 


S$rs = mssql_query ( "select * from tb_demo10" ); 
if (isset ( $_POST [sub] )) { 
站 ($_POST [text] == "|| $_POST [text] == "请 输入 数字 ") { 
> "<script>alert( 请 在 文本 框 中 输入 信息 );</script>"; 
} else 
if (! preg_match ( "Ad/",$_POST [text] )) { 
echo "<script>alert( 请 输入 数字 )</script>"; 
}else{ 
if ($_POST [text] > 3) { 
echo "<script>alert( 超 出 取 值 范围 );</script>"; 
}else{ 
$ts = @mssql_fetch_field ( $rs, $_POST [text] ); 
和 


2> 
<table bgcolor="#DEED88" width="580px"> 
<tr> 


<td class="0">name</td> 
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<td class="0">column_source</td> 
<td class="0">type</td> 
<td class="0">max_length</td> 
</tr> 
<tr> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $ts->name )?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk', ‘utf-8', $ts->column_source )?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk', ‘utf-8, $ts->type )?></td> 
<td style="backeround: #FFFFFF"><?php echo iconv ( gbk， ‘utf-8", Sts->max_length )?></td> 


<2php 
} 


} 
}else{ 
?> 


图 秘笈 心 法 


心 法 领悟 475: 使 用 mssql_fetch_field0 函 数 的 注意 事项 。 
mssqlL_fetch_field0 函 数 可 以 用 来 从 某 个 查询 结果 中 获取 字段 的 信息 。 如 果 没 有 指定 字段 偏 移 量 ， 则 下 一 个 
尚未 被 mssql_fetch_field0 函 数 获取 的 字段 被 提取 。 


图 实例 说 明 

实例 475 中 通过 mssql_fetch_field0 函 数 返回 对 象 的 name 属性 获取 字段 的 名 称 , 下 面 将 介绍 在 mssql 函数 库 
中 专门 用 来 获取 字段 名 称 的 方法 。 运 行 本 实例 ， 在 文本 框 中 输入 一 个 有 效 的 字段 值 ， 单 击 “ 确 定 ” 按 钮 ， 将 输 
出 如 图 10.9 所 示 的 页 面 。 


dbl A 区 


四 CE 


图 书 儿 称 图 书 价格 ”出版 日 期 
《PHP 开 友 实 战 宝 拱 》 73 元 20LU/ 八 月 /31 % 00 
各 1 


人 RFR 元 2010/ 作 月 /31 0: 00 
i pr 


10.9 利用 mssql_field_name(0 函 数 获取 字段 名 称 


图 关键 技术 


本 实例 主要 应 用 mssql_field_name(0 函 数 获取 字段 的 名 称 ， 其 语法 如 下 : 


string mssql_field_name ( resource result, int field_index ) 
该 函数 返回 指定 字段 索引 的 字段 名 。 人 参数 result 必须 是 一 个 合法 的 结果 标识 符 ， 参 数 field_index 是 该 字段 
的 数字 偏 移 量 。 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 ， 首 先 ， 创 建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 ， 执 行 查询 语句 ， 并 
通过 while 语句 和 mssql_fetch row(0 函 数 循环 输出 查询 结果 集中 的 数据 。 最 后 ， 获 取 表 单 提交 的 数据 ， 应 用 
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mssql_field_name(0 函 数 获取 指定 字段 的 名 称 ， 其 代码 如 下 : 


<?php 


if (isset ( $_POST [sub] )) { 
让 ($_POST [te] 一 "||$_POST [te] 一 "输入 数字 ") { 
echo "<script>alert( 请 在 文本 框 中 输入 内 容 );</script>"; 


}else{ 
证 (preg_match ("Nd/", $_POST [te] )) { 
if ($_POST [te] > 4) { 
echo "<script>alert( 输 入 的 数字 超出 范围 );</script>"; 
}else{ 
$rss = mssql_field_name ( $rs, $_POST [te] ); 
} 
}else { 
echo "<script>alert( 您 输入 的 不 是 数字 ');</script>"; 
} 
?> 


<tr> 

<td bgcolor="#EFFFFFF"> 数 据 表 字段 名 称 为 </td> 

<td bgcolor="#FFFFFF" style="color: #FF0000"><?php echo S$rss:?></td> 
</tr> 
<?php 

} 


?> 
图 秘 签 心 法 

心 法 领悟 476: 使 用 mssql_field_name() 函 数 的 注意 事项 。 

在 使 用 此 函数 时 ， 参 数 field_index 从 0 开始 。 例 如 ， 第 3 个 字段 的 索引 值 其 实 是 2， 第 4 个 字段 的 索引 值 
是 3， 依 次 类 推 。 
高 级 


实例 477 趣味 指数 : 


图 实例 说 明 


从 结果 集中 获取 数据 的 方法 有 很 多 ， 本 实例 主要 讲解 利用 数据 对 象 输出 结果 集中 的 数据 。 运 行 本 实例 如 
图 10.10 所 示 。 


oooooe 


《PRP 开 发 实战 字典 》 73 元 


1 
党 《PHP 标 准 教程 》 39 元 
3 《PHP 网 络 编程 宝 和 与 》 7 玩 
4 《PhP 范例 字典》 9 元 
5 《PHP 范 例 手 册 》 人 元 010/ 八 月 13! 0 00 


图 10.10 通过 结果 集 对 象 输出 数据 


图 关键 技术 


mssql_fetch_object0 函 数 ， 从 结果 集中 获取 一 行 作为 对 象 ， 如 果 没 有 更 多 行 则 返回 FALSE， 其 语法 如 下 : 

object mssql_fetch_object ( resource result ) 

该 函数 和 mssql_fetch_array0 函 数 类 似 ， 只 是 返回 一 个 对 象 而 不 是 数组 ， 即 只 能 通过 字段 名 来 访问 数据 ， 而 
不 是 偏 移 量 〈 数 字 是 合法 的 属性 名 ) 。 
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图 设计 过 程 

(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 

(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssqlL_query(0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_object0 函 数 循环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 


<p! 
while ( $rst = mssql_fetch_object ( $rs) ) { 


<td style="backeround: #FFFFFF"><?php echo iconv ( "gbk”, "utf-8", $rst->id ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", $rst->bname ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", $rst->price );?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk","utf-8",$rst->date):?></td> 


也 笈 心 法 
心 法 领悟 477: 使 用 mssql_fetch_object0 函 数 的 注意 事项 。 
使 用 mssql_fetch_object0 函数 时 需要 注意 ， 此 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


高 级 
起 指 雪人 究 久久 


图 实例 说 明 


实例 477 中 讲解 了 通过 结果 集 对 象 输出 数据 ， 下 面 将 通过 另外 一 个 函数 将 结果 集 以 数组 的 形式 输出 。 运 行 
本 实例 ， 结 果 如 图 10.11 所 示 。 


通过 结 老 肥 到 组 镁 出 致 据 


图 书 ID 图 书 各 入 图 书 价 格 出 版 日 其 
长 PRP 开 发 实战 宝典 》 ps 元 2010/ 和 有 /3 0: 00 
《PRP 标 准 教程 》 9 元 2010/ 八 月 /131 0: 00 
《PRP 网 络 编 程 宝 共 } 1 和 远 2010/ 八 月 /131 0 00 
《PRFP 范 例 宝 奥 》 区 20t0/ 八 月 /31 00 
《PRP 范 例 手 册 》 68 元 20t0/ 人 月 /3Lk00 


图 10.11 通过 结果 集 数 组 输出 数据 


图 关键 技术 


本 实例 主要 应 用 mssql_fetch_assoc0 函 数 ， 从 结果 集中 获取 一 行 作为 关联 数组 。 如 果 没 有 更 多 行 则 返回 
FALSE， 其 语法 如 下 : 
array mssql_fetch_assoc ( resource result_id ) 


参数 result_id 为 指定 的 结果 集 。 
图 设计 过 程 


(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 
(2) 创建 index.php 文件 ， 包 含 数据 库 连接 文件 ， 通 过 mssql_query0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_assoc0 函数 循环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 
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<?php 
include_once ("conn.php"); 
S$rs = mssql_query ( "select * from tb_demo10" ); 


?> 
<table width="580px" bgcolor="#FC8C7E"> 
<tr> 
<td style="color: #FFFFFF; text-align: center"> 图 书 ID</td> 
<td style="color: 部 FFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: #EFFFFF; text-align: center"> 出 版 日 期 </td> 
</tr> 


p 
while ( $rst = mssql_fetch_assoc ( $rs ) ) { 


<tr> 
<td style= background: #FFFFFF"><?php echo iconv ( gbk，utf-8 , $rst [id] ); ?></td> 
<td style= "background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $rst [bname] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk’, ‘utf-8", $rst [price] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $rst [date] ); ?></td> 


以 徐 心 法 
心 法 领悟 478: 使 用 mssql_fetch_assoc0 函 数 的 注意 事项 。 


由 于 本 函数 返回 的 是 一 个 关联 数组 ， 所 以 在 获取 数组 中 的 元 素 时 必须 使 用 字段 名 称 作为 数组 的 索引 ， 同 时 
还 要 注意 ， 其 数组 的 索引 是 区 分 大 小 写 的 。 


实例 479 


图 实例 说 明 


如 果 用 户 只 想 查 看 用 户 名 或 者 只 想 查看 单一 的 一 项 数据 ， 程 序 员 就 没有 必要 在 与 数据 库 的 交互 中 取得 一 行 
数据 ， 只 需要 从 数据 库 中 取得 单一 字段 信息 即 可 。 本 实例 通过 函数 mssql_result0 实 现 获取 结果 数据 ， 运 行 结果 
如 图 10.12 所 示 。 


《PHP 网 站 编 程 宝 此 | 

本 忆 到 利 xo% | 
1 《PRP 开 - 起 和 而 

9 《PRP 标注 教程 } 

3 《PP 辣 络 坊 树 宝 天 》 

‘ 《PRP 范例 主 烘 } 


5 《PP 区 全 手册 


图 10.12 ”返回 结果 集中 的 单元 内 容 


转 关键 技术 
本 实例 的 关键 点 是 如 何 运用 mssql_result0 函数 返 回 结果 集中 的 单元 内 容 ， 其 语法 如 下 : 


string mssql_result ( resource result, int row, mixed field ) 
参数 说 明 : 
resource result: 结果 集 。 
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int row: 列 数 。 
mixed field: 指定 字段 。 
图 设计 过 程 

(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 

(2) 创建 index.php 文件 ， 首 先 ， 创 建 form 表单 ， 提 交 指 定 要 查询 的 列 数 和 字段 名 称 。 然 后 ， 包 含 数据 库 
连接 文件 , 通过 mssql_query0 函 数 执行 查询 操作 , 通过 while 语句 和 mssql_fetch_row0 函 数 循环 输出 查询 结果 集 
中 的 数据 。 接 着 ， 对 form 表单 中 提交 的 数据 进行 判断 ， 如 果 符 合 要 求 则 运用 mssql_result0 函 数 获取 结果 集中 指 
定单 元 的 内 容 ， 其 关键 代码 如 下 : 


<?php 
} 
if (isset ( $_POST [sub] )) { 
Stext = $_POST [te]; 
$select = $_POST [select]; 
if($_POST [te] == ""||$_POST [te] 一 "输入 数字 ") { // 判 断 输入 的 值 是 否 为 空 
echo "<script>alert( 文 本 框 不 能 为 空 )</script>"; 
}else { 
证 (preg_match ("Ad/”, $text )) { 1/ 判断 输入 的 值 是 否 是 数字 
if ($text < 5) { 
S$rst = mssql_result ( $rs, $text, $select ); /| 获取 指定 单元 的 内 容 
echo iconv ( ‘gbk', ‘utf-8,, $rst ); /输出 指定 单元 的 内 容 
}else{ 
echo "<script>alert( 文 本 框 超出 取 值 范围 );</script>"; 
}else{ 
echo "<script>alert( 文 本 框 输入 的 不 是 数字 ”);</script>"; 
} 
} 
} 


图 秘笈 心 法 
心 法 领悟 479: 使 用 mssql_result0 函 数 的 注意 事项 。 
在 使 用 此 函数 的 int rows 参数 时 要 注意 下 标 是 以 0 开始 的 , 如 在 页 面 中 输入 数字 2, 其 实 是 表示 第 1 个 数据 单元 。 


力 实例 说 明 
在 创建 数据 表 时 ， 需 要 定义 字段 的 最 大 长 度 ， 如 果 插 入 的 数据 信息 超过 这 个 最 大 长 度 ， 字 段 就 不 能 完整 地 
输出 。 运 行 本 实例 ， 通 过 函数 自动 获取 字段 信息 的 长 度 ， 结 果 如 图 10.13 所 示 。 


3 3 | 
利用 国 数 返 @ 施 定 字段 的 长 度 

EIN 
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出 版 日 

1 《PHP 开 发 实战 宝典 》 73 元 2010/ 入 月 /31 0:00 

1 《FHP 标准 教程》 19 无 3010/AA/Y 0:00 

了 《PHF 网 阁 编程 宝典 》 7 玩 2010/ 人 月 /31 0:00 

4 《PHP 范 全 宝 奥 》 9 元 2010/ 入 月 /31 0:00 

了 《PHF 范 便 手 册 》 6 元 20t0/ 八 有 34 0:00 


图 10.13 返回 指定 字段 的 长 度 
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力 关键 技术 
获取 指定 字段 的 长 度 应 用 的 是 mssql_field_length0 函 数 ， 其 语法 如 下 


int mssql_field_length ( resource result, int field_offset ) 

参数 说 明 : 

resource result: 结果 集 。 

int field_offset: 字段 数 。 
图 设计 过 程 

(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 

(2) 在 index.php 文件 中 ， 创 建 form 表单 ， 提 交 指 定 要 查询 的 字段 值 ， 并 且 将 数据 提交 到 本 页 。 

(3) 在 index.php 文件 中 ， 包 含 数据 库 连 接 文件 ， 执 行 查询 语句 ， 完 成 数据 表 中 数据 的 循环 输出 ， 并 对 表 
单 中 提交 的 值 进行 判断 ， 如 果 符 合 要 求 ， 则 应 用 mssql_field_length0 函 数 获取 表单 提交 的 字段 的 长 度 值 ， 并 且 输 
出 ， 二 

<?php 


include_once ("conn.php"); 
$rs = mssql_query ( "select * from tb_demo10" ); 
?> 


<table width="580px" bgcolor="#FEF1BA"> 
<tr> 


<td style="color: #FFFFFF; text-align: center"> 图 书 ID</td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: #EFFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: #FFFFFF; text-align: center"> 出 版 日 期 </td> 
</tr> 
<?php 
if (isset ($_ POST [sub] ){ 
Srss = mssql_field_length ( $rs, $_POST [select] ); 
echo "<font size='+1' color='red'> 字 段 长 度 为 ". $rss . "</font>"; 


} 
while ( $rst = mssql_fetch_row ( $rs) ) { 
?> 


<tr> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk，utf-8', $rst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $rst [1] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk', ‘utf-8', $rst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk', ‘utf-8', $rst [3] ); ?></td> 


<?php 
} 


?> 
图 秘笈 心 法 
心 法 领悟 480: 获取 数据 表 中 指定 字段 的 类 型 。 


在 mssql 函数 库 中 ， 不 但 可 以 获取 到 数据 表 中 指定 字段 的 名 称 、 长 度 、 定 位 指针 位 置 ， 而 且 可 以 获取 到 字 
段 的 类 型 ， 其 应 用 的 是 mssql_field_type(0 函 数 。 


| 
趣味 指数 : 帘 窒 全 窗 : 


图 实例 说 明 
通过 上 面 的 实例 ， 相 信 读 者 已 经 掌握 了 如 何 利用 函数 获取 字段 的 长 度 。 下 面 将 讲解 如 何 利用 函数 获取 指定 
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字段 的 字段 类 型 。 运 行 本 实例 ， 如 图 10.14 所 示 。 


利用 对 数 抬 加 痢 定 字 段 的 类 型 
05 <) 
字段 类 型 为 char | 
日 期 了 弘 
[ 《PRP 开 发 实战 宝典 》 7 元 2010/ 人 入 月 /31 0 00 
日 《PHP 标 本 教程 》 79 元 2010/ 八 月 /31 m 00 
3 《PHP 网 终 编 程 宝典 》 7 庄 2010/ 八 月 /31 m 00 
4 《PHP 范 例 宝典 》 9 元 2010/ 入 月 131 0: 00 
5 《PHP 落 例 手 册 》 65 元 2010/ 八 有 131 Oo0 


图 10.14 返回 指定 字段 的 类 型 


键 技术 
本 实例 主要 应 用 mssql_field_type0 函 数 ， 获 取 结 果 集中 指定 字段 的 类 型 ， 其 语法 如 下 : 


String mssql_field_type ( resource result [, int offset] ) 
参数 说 明 : 

resource result: 结果 集 。 

int field_offset: 字段 数 。 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 
(2) 在 index.php 文件 中 , 创建 form 表单 ,提交 指定 要 查询 的 字段 值 ,并且 将 数据 提交 到 本 页 ， 其 代码 如 下 : 


<form action="" method="post"> 
<select name="select"> 
<option value="0">ID 字段 </option> 
<option value="1"> 名 称 字段 </option> 
<option value="2"> 价 格 字段 </option> 
<option value="3"> 日 期 字段 </option> 
‘</select> 
<input type="submit" name="sub" value="" class="two" /> 
</form> 
(3) 在 index.php 文件 中 ， 包 含 数据 库 连 接 文件 ， 执 行 查询 语句 ， 完 成 数据 表 中 数据 的 循环 输出 ， 并 对 表 
单 中 提交 的 值 进行 判断 ， 如 果 符 合 要 求 ， 则 应 用 mssql_field_type 0 函数 获取 表单 提交 的 字段 的 类 型 值 ， 并 且 输 
出 ， 其 关键 代码 如 下 : 
<?php 
include_once ("conn.php"); 
$rs = mssql_query ( "select * from tb_demo10" ); 
?> 
上 (isset ($_ POST [sub] )) { 
S$rss = mssql_field_type ( $rs, $_POST [select] ); 
echo "<font size= +l color='red > 字段 类 型 为 ". $rss . "</font>"; 


‘while ( $rst = mssql_fetch_row ($rs)){ 


<td style="background: #FFFFFF"><?php echo iconv (wbk, utf-8', Srst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv (‘gbk,, ‘utf-8', Srst [1 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk,, ‘utf-8', Srst [2] 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk,, ‘utf-8', $rst [3] ); ?></td> 


<2php 
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图 秘笈 心 法 


心 法 领悟 481: SQL Server 数据 库 中 的 字段 类 型 。 
SQL Server 数据 库 中 的 数据 类 型 与 MySQL 数据 库 中 的 数据 类 型 有 所 不 同 ，SQL Server 中 的 字段 类 型 包括 


int、real、string、blob、date 等 。 


力 实例 说 明 
在 SQL Server 数据 库 中 ， 取 得 结果 集中 的 字段 数目 其 实 与 操作 MySQL 数据 库 大 同 小 异 。 下 面 就 来 讲述 如 
何在 SQL Server 数据 库 中 取得 结果 集中 的 字段 数目 ， 运 行 结果 如 图 10.15 所 示 。 


当前 数据 表 字 段 数目 为 4 


《PHP 开 发 舌 浇 宝典 》 78 元 2010/ 作 月 /3 0: 00 
《PHP 标 准 教程 》 1 哆 2010/ 八 月 /31 0 00 
【7 j 现 UN 月 /30 0 00 
《PHP 范 侈 宝 热 》 元 201M 八 月 /3 0 00 
《PHP 范 例 手 册 》 元 201MA 有 /3 0:00 


图 10.15 ”获取 结果 集 的 字段 数目 


图 关键 技术 


获取 结果 集 的 字段 数目 主要 应 用 mssql_num_fields0 函 数 ， 其 语法 如 下 : 
int mssql_num_fields( resource result ) 
参数 resource result 指 结果 集 。 


图 设计 过 程 
(1) 新 建 conn.php 文 件 ,通过 mssql_connect(0 函 数 连 接 SQL Server 数 据 库 服务 器 ,然后 通过 mssql_select_db0 
函数 连接 db_database10 数据 库 ， 其 代码 如 下 : 
<zphp 


$conn = mssql_connect("localhost","sa","") or die ("连接 SQL Server 时 发 生 错 误 "); 
mssql_select_db("db_database10",$conn) or die ("连接 数据 库 发 生 错误 "); 
?> 


(2) 创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssql_query0 函数 执行 查询 语句 ， 应 用 
mssqlL_num_fields0 函 数 获取 查询 结果 集中 总 的 字段 数 , 并 且 通 过 while 语句 和 mssql_fetch_row(0 函 数 完成 查询 结 


果 集 中 数据 的 循环 输出 ， 代 码 如 下 : 
<?php 
include_once ("conn.php"); 
S$rs = mssql_query ( "select * from tb_demo10" ); 
if ($_GET [idl =1) { 
= mssql_num_fields ( $rs ); 
echo "<font size= +l color= red > 当前 数据 表 字 段 数目 为 " . $rss . "</font>"; 


¥ 
?> 
<table width="580px" bgcolor="#CCE587"> 
<tr> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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< 
while($rst = mssql_fetch_row($rs)){ /循环 输出 


<td bgcolor="#FFFFFF"><?php echo iconv(gbk','utf-8",$rst[0]);?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv(gbk'utf 8',Srst[1]):?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv(gbk','utf-8',$rst[2]);?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv(gbk','utf-8',$rst[3]);?></td> 
</tr> 


<?php 


} 
if($_GETlid] 一 D{ 1/ 当 按钮 被 单 击 
S$rss = mssql_num_rows($rs); /返回 结果 

?> 
<tr><td bgcolor="#FFFFFF"> 数 据 表 数据 <htd><td bgcolor="#EFFFFF"> 信 息 数 量 为 </td><td bgcolor="#FFFFFF"><?php echo $rss:?></td><td 
bgcolor="#FFFFFF"></td></tr> 
<?php 

} 
?> 


由 于 SQL Server 数据 库 中 使 用 的 是 gbk 编码 格式 ， 而 本 实例 的 页 面 应 用 的 是 utf-8 编码 ， 所 以 在 输出 数据 
库 中 的 数据 时 需要 应 用 iconv0 转 码 函 数 对 数据 库 的 编码 格式 进行 转换 ， 否 则 将 输出 乱码 
图 秘笈 心 法 


心 法 领悟 483: 使 用 mssql_num_rows0 函 数 的 注意 事项 。 
mssql_num_rows() 函 数 仅 对 select 语句 有 效 。 


高 级 
趣味 指数， 坎 诊 商 商 


| 
: 
: 


力 实例 说 明 


在 输出 数据 信息 后 要 及 时 释放 结果 内 存 以 节省 内 存 空 间 。 也 许 用 户 会 觉得 ， 不 释放 结果 内 存 并 没有 什么 严 
重 影响 。 这 是 因为 用 户 本 机 上 运行 的 实例 ， 数 据 结果 很 小 ， 对 于 计算 机 运算 速度 来 说 没有 太 大 的 影响 。 但 是 如 
果 结果 集中 包含 大 量 的 数据 ， 计 算 机 的 运算 速度 就 会 明显 变 慢 。 运 行 本 实例 ， 通 过 mssql_free_result0 函 数 释放 
结果 内 存 ， 如 图 10.17 所 示 。 


二 freea result 电 至 的 应 用 


图 书 I0 图书 名 称 

上 《PHP 开 发 实战 宝典 》 
《PHP 标准 教程 》 

3 《PHP 网 络 编 程 宝典 》 
4 《PKP 范 例 宝典 》 

5 《PHP 范 例 手册 》 


出 版 日 其 
2010/ 八 月 /31 0: 00 


10.17 释放 结果 内 存 


图 关键 技术 
本 实例 主要 应 用 mssql_free_result0 函数 释放 结果 内 存 ， 其 语法 如 下 


bool mssql_free_result (resource result ) 


该 函数 将 释放 所 有 与 结果 标识 符 result 相关 联 的 内 存 。 
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设计 过 程 


创建 index.php 脚本 文件 ， 包 含 数据 库 连接 类 ， 对 类 进行 实例 化 操作 ， 完 成 与 db_database10 数据 库 的 连接 ， 
并 循环 输出 数据 表 中 的 数据 ， 当 单 击 “ 释 放 结 果 内 存 ” 超 链接 时 ， 执 行 释放 结果 集 的 操作 ， 代 码 如 下 : 
<?php 


include_once("conn.php"); 1/ 包含 数据 库 文件 
$ms = new Mssql("localhost","sa","","db_database10"); /实例 化 对 象 
$rs = mssql_query("select * from tb_demo10"); 
?> 
<?php 
while($rst = mssql_fetch_row($rs)){ /循环 输出 
?> 
<tr> 
<td bgcolor="#FFFFFF"><?php echo iconv(gbk,utf-8,Srst[0]);?></td> 
td bgcolor="#FFFFFF"><?php echo iconv(gbk',utf-8',$rst[1]);?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv (‘gbk",'utf-8", $rst[2]);?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv (‘gbk",'utf-8", $rst[3]);?></td> 
<ltr> 
<?php 
if($_GET[idl == D{ 
$ms -> free_result($rs); /释放 结果 集 
} 
?> 


秘笈 心 法 
心 法 领悟 484: 详解 mssql_free_result0 函 数 。 


mssql_free_result( 函 数 将 释放 所 有 与 结果 标识 符 result 相关 联 的 内 存 , 仅 需要 在 考虑 到 返回 很 大 的 结果 集 时 
会 占用 较 多 内 存 时 调用 ， 在 脚本 结束 后 所 有 关联 的 内 存 都 会 被 自动 释放 。 
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力 实例 说 明 


在 程序 运行 结束 后 ， 不 但 要 释放 结果 内 存 ， 还 要 关闭 与 数据 库 的 连接 以 节省 系统 资源 。 运 行 本 实例 ， 单 击 
“关闭 连接 ” 超 链接 ， 将 输出 提示 ， 运 行 结果 如 图 10.18 所 示 。 


铝 imssql close() 思 致 的 应 用 


图 书 ID ”图书 名 称 
[ 


《PHP 开 发 实战 宝典 》 
1 《PHP 标 准 教 标 》 
3 《PHP 网 纤 编 程 宝典 》 
4 《PHP 范 例 宝 典 》 
5 《PHP 范 例 手 册 》 


图 10.18 关闭 与 数据 库 的 连接 


力 关键 技术 
本 实例 主要 是 通过 编写 数据 库 类 并 通过 对 象 句柄 调用 mssql_close0 函 数 实现 关闭 数据 库 连 接 的 操作 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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Server 数据 库 的 连接 ， 其 中 通过 两 种 方法 连接 数据 库 : 通过 mssql_connect0 函 数 实现 与 数据 库 的 暂时 连接 、 通 
过 mssql_pconnect0 函 数 实现 与 数据 库 的 永久 连接 。Mssql 类 的 代码 如 下 : 
<?php 
class Mssql{ 
Var $host; 
Var $user; 
var $pwd; 
Var $conn; 
public function __construct($host,$user,$pwd, $conn) { /构造 函数 
S$this -> host = $host; 
Sthis -> user = $user; 
Sthis -> pwd = $pwd; 
S$this -> conn = $conn; 
S$this -> connect(); 


} 
public function connect0{ 
if($this -> conn == "pconn ){ 
S$this -> conn = mssql_pconnect($this -> host,$this -> user,$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建立 永久 连接 );</script>"; 
Jelse{ 
S$this -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建立 暂时 连接 );</script>"; 
} 
} 
} 
?> 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 编 写 数据 库 连接 类 ， 其 完整 代码 请 参考 关键 技术 中 的 内 容 。 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 提 交 连 接 数据 库 所 使 用 的 方式 。 然 后 ， 包 含 数据 库 连接 类 ， 执 
行 类 的 实例 化 操作 ， 并 调用 connect0 方 法 完成 与 数据 库 的 连接 ， 其 关键 代码 如 下 : 


<?php 
include_once("conn.php"); // 包 含 数据 库 连 接 类 
iflisset($_POST[subj)){ 1/ 判断 按 钮 是 否 被 单 击 
if($_POSTIselect] 一 1 判断 下 拉 列 表 框 内 容 
echo ee 式 );</script>"; 
Jelse{ 
$ms = new Mssql("localhost","sa","",$_POSTIselect]); /实例 化 对 象 
} 
} 
?> 
力 秘笈 心 法 


心 法 领悟 486: 对 两 种 连接 方式 的 选择 。 

永久 连接 和 暂时 连接 从 功能 上 说 都 可 以 实现 与 数据 库 的 连接 操作 。 至 于 如 何 选择 ， 一 般 都 是 程序 员 的 个 人 
爱好 问题 。 笔 者 喜欢 用 暂时 连接 的 方式 ， 虽 然 在 操作 完 数 据 库 后 须 及 时 关闭 与 数据 库 的 连接 ， 但 是 在 结构 上 较 
为 鲜明 。 


高 级 | 
趣味 指数 : bebo 
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力 实例 说 明 


在 实际 Web 开发 过 程 中 ,无论 是 前 台 还 是 后 台 经 常会 用 到 向 数据 库 中 添加 信息 这 一 模块 ， 如 果 所 用 之 处 都 
重复 编写 代码 ， 这 会 使 整个 项 目的 代码 重用 率 大 大 降低 。 为 了 克服 上 述 缺 陷 ， 可 以 通过 一 个 数据 信息 添加 类 来 
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实现 某 项 目 中 的 所 有 信息 的 添加 工作 .运行 本 实例 ,图 书 添 加 页 面 及 查看 图 书信 息 页 面 分 别 如 图 10.20 和 图 10.21 
所 示 ， 首 先 在 图 10.20 所 示 的 表单 中 输入 某 图 书 的 信息 ， 单 击 “ 添 加 ”按钮 即 可 将 图 书信 息 添 加 到 数据 库 中 ， 
同时 可 以 在 图 10.21 所 示 的 页 面 中 查看 所 有 已 经 添加 的 图 书信 息 。 


En/ 


| 刘 览 图书 信息 | 浙 加 图 信息 | 


梓 
bt 人 光斑 技巧 》 明日 科技 和民 邮 电 出 版 社 2007-01-03 
傅 : 《“* 数 各 库 开 尼 元 全 于 革 》 明日 科技 人 民 邮 电 出 版 社 2006-12-03 
[日 人 网 宝典 》 明日 科技 人 民 邮 电 出 版 社 2006-01-03 
画 副 加 四 He 2003-12.09 
10.20 添加 图 书信 息 图 10.21 浏览 图 书信 息 


图 关键 技术 


本 实例 的 关键 是 如 何 编写 通用 的 添加 信息 类 ， 其 实现 的 基本 原理 是 : 通过 构造 函数 对 要 执行 的 SQL 语句 进 
行 初始 化 ， 这 样 即使 表 中 的 字段 数目 不 同 也 可 以 实现 将 图 书信 息 添 加 到 数据 库 中 ，addbook 类 的 代码 如 下 : 
?php 


class addbook { 

private $add_sql; /定义 私有 变量 

public function __construct($x) { /定义 构造 函数 
Sthis->add_sql = $x; // 为 变量 赋值 

} 

public function add0 { /定义 添加 数据 的 方法 
include_once ("conn.php"); 
if (@mssql_query ( $this->add_sql, $conn 

echo DOr nD sory pack: <Jscript>"; 

}else { 


echo "<script>alert( 新 书 添加 失败 !);history.back0;</script>"; 
} 


E 

} 

$bookname = $_POST [bookname]; 

$auto = $_POST [auto]; 

S$pub = $_POST [pub]; 

$pubtime = $_POST [pubtime]; 

$sql = "insert into tb_demo08(bookname,auto,pub,pubtime)values($bookname','$auto','$pub','$pubtime’)"; 
$adbook = new addbook ( $sql ); 


?> 

该 类 定义 一 个 私有 的 数据 成 员 $add_sql 用 于 保存 传 入 该 类 的 查询 语句 ， 并 通过 构造 函数 _construct0 实 现 对 
该 私有 成 员 的 初始 化 ， 最 后 定义 该 类 的 成 员 函 数 add0 执 行 添加 操作 。 
图 设计 过 程 

(1) 新 建 conn.php 文件 ， 完 成 与 数据 库 的 连接 。 

(2) 新 建 addbook.php 文件 ， 创 建 form 表单 ， 提 交 要 添加 的 图 书信 息 ， 将 图 书信 息 提 交 到 savebook.php 
文件 中 。 添 加 图 书信 息 的 页 面 效 果 如 图 10.20 所 示 。 

(3) 创建 savebook.php 文件 ， 编 写 数据 添加 类 ， 定 义 addbook( 方 法 执行 数据 的 添加 操作 。 在 该 文件 中 完 
成 类 的 实例 化 操作 , 并 通过 返回 的 对 象 调 用 类 中 的 addbook0 方 法 , 根据 表单 中 提交 的 数据 定义 insert 添加 语句 ， 
最 终 执行 数据 的 添加 操作 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 

(4) 新 建 index.php 文件 ， 循 环 输出 数据 表 中 存储 的 图 书信 息 ， 其 关键 代码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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public function Delete0{ // 定 义 删除 方法 
if(l$rs = @mssql_query ($this -> sqD){ // 如 果 执 行 删除 操作 发 生 错误 
echo "<script>alert(SQL 语 旬 错误 );</script>"; WJavaScript 提示 
Jelse{ 
echo "<script>alert( 删 除 成 功 );location.href='index.php?id=1';</script>"; 
} 
} 
} 
?> 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 编 写 数据 库 连 接 类 ， 完 成 与 SQL Server 数据 库 的 连接 ， 其 代码 如 下 : 


<?php 


class ConnDemof /定义 类 名 称 
var $host; /主机 名 称 
Var $user; UI 用 户 名 称 
var $pwd; /用 户 密码 
var $db; / 怕 据 库 名 称 
var $conn; /连接 标识 符 
var $tb; /数据 表 名 称 
public function __construct($host,$user,$pwd,$db, $tb) { // 物 造 函 数 
Sthis -> host = $host; 
S$this -> user = $user; 
Sthis -> pwd = $pwd; 
S$this -> db = $db; 
Sthis -> tb = $tb; 
S$this -> connect(); 
} 
public function connect0{ 
S$this -> conn = $conn; 
Sthis -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd) or die ("Connect mssql false"); 
mssql_select_db($this -> db,$this -> conn) or die ("Connect Database false"); 
} 
} 
?> 


(2) 新 建 delete.php 文件 ， 编 写 数据 库 删 除 类 ， 并 继承 数据 库 连 接 类 ， 其 代码 如 关键 技术 中 所 示 。 

(3) 新 建 index.php 文件 。 首 先 ， 创 建 form 表单 ， 提 交 图 书 的 JD 值 ， 作 为 执行 删除 操作 的 条 件 。 然 后 ， 
包含 数据 删除 类 文件 ， 执 行 DeleteDemo 类 的 实例 化 操作 ， 并 且 向 类 中 传递 参数 。 接 着 ， 执 行 查询 语句 ， 循 环 输 
出 数据 表 中 的 数据 。 最 后 ， 根 据 form 表单 提交 的 值 ， 通 过 类 实例 化 返回 的 对 象 调 用 Delete0 方 法 执行 删除 操作 ， 
其 关键 代码 如 下 : 


<?php 
include ("delete.php"); 
$dd = new DeleteDemo ( "localhost", "sa", "", "db_database10", "tb_demo09" ); 
if ($_GET [idl == "1") { 
$rst = mssql_query ( "select * from tb_demo09" ); 
?> 
<form action="" method="post"> 
<input type= "text" size="10" name="text" value=" 输 入 ID 删除 " onfocus="this.value="" class="one" /> 
<input type="submit" name="sub" value="&nbsp;" class="two" /> 
</form> 
<table width="580px" bgcolor="#FA7672"> 
<tr> 


<td align="center"> 图 书 名 称 </td> 
<td align="center"> 作 者 </td> 
<td align="center"> 出 版 社 </td> 
<td align="center"> 出 版 时 间 </td> 
</tr> 
<?php 
while ( $rstt = mssql_fetch_row ( $rst ) ) { 
?> 
<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo iconv (‘gbk', ‘utf-8', $rstt [0] ):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv (‘gbk', ‘utf-8', Srstt [1] );?></td> 
<td align="center" bgcolor="#F FFFFF"><?php echo iconv (‘gbk', ‘utf-8', Srstt [2] );?></td> 
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<td align="center" bgcolor="#FFFFFF"><?php echo iconv ('gbk,'utf-8', $rstt [3] ):?></td> 


<?php 
i 
i ($_POST [subl) { // 判 断 提 交 按 钮 的 值 
S$te = $_POST[text]; /| 获取 提交 的 了 D 
$dd -> SQL($te); // 调 用 SQL 方法 定义 delete 删除 语句 
$dd -> Delete(; /调用 Delete0 方 法 执行 删除 操作 
} 
2 
<hd> 
<htr> 
</table> 


图 秘笈 心 法 


心 法 领悟 488: 类 的 继承 。 
少数 面向 对 象 的 语言 (如 C++、Smalltalk 等 ) 支持 多 继承 ， 即 一 个 子 类 有 多 个 父 类 。 但 是 PHP 自身 不 支持 
多 继承 ， 只 支持 单 继承 ， 即 一 个 子 类 只 有 一 个 父 类 。 


实例 489 


趣味 指数 : 会 傅 傅 窗 | 


图 实例 说 明 


实现 更 新 图 书信 息 类 与 删除 图 书信 息 类 大 同 小 异 ， 只 是 将 删除 图 书信 息 类 中 的 两 个 核心 方法 蔡 换 为 更 新 操 
作 的 方法 即 可 。 运 行 本 实例 ， 执 行 图 书信 息 的 更 新 操作 ， 其 运行 效果 如 图 10.23 所 示 。 


图 书信 息 
个 因 书 名称 个 作者 个 出 退社 个 出 版 6 期 
和 ep 


图 书 10 。 图书 吉林 作者 EL 出 版 日 其 
1 | PRP 苑 创 宣 烛 | 明日 科技 有 限 公司 “| 人 民 邮 昌 册 版 社 | 2111/ 入 月 /11 D:D 
2 | PhP 自学 生前 | 明日 科技 有 限 公司 “| 人 民 邮 电 员 县 社 | 2WW/ 入 月 /11 0: 00 
了 “| PFP 实 硬 字 旨 | 明日 科 技 有 限 公司 | 人民 闻 电 出 版 社 | 211U 入 万 711 0: 0 


图 10.23 更 新 图 书 类 的 实现 


更 新 图 书 类 UpdateDemo 同样 集成 数据 库 连 接 类 ConnDemo， 与 数据 库 删除 类 的 唯一 不 同 之 处 是 在 SQL 方 
法 中 ， 定 义 的 是 update 更 新 语句 。UpdateDemo 类 的 代码 如 下 : 


class UpdateDemo extends ConnDemo{ /| 继承 抽象 类 
var $sql; /定义 变量 
public function SQL($Condition1,$Condition2,$id){ /定义 方法 拼接 字符 串 
Sthis -> sql = $sql; 
S$this -> sql = "update ".$this -> tb." set $Condition1='$Condition2’ where id=$id"; /拼接 字符 串 
Teturn $this -> sql; 

» 

public function update0{ // 更 新 操作 方法 
mssql_query($this -> sqD){ 

echo "<script>alert( 更 新 操作 以 成 功 ):location.href='index.php?id=1';</script>"; WJavaScript 提示 

Jelse{ 


echo "<script>alert(SQL 语句 发 生 错 误 );</script>"; 
} 
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} 
} 
?> 


图 设计 过 程 
(1) 在 conn.php 文件 中 ， 首 先 ， 编 写 ConnDemo 数据 库 连 接 类 ， 通 过 connect( 方 法 完成 与 SQL Server 数 
据 库 的 连接 。 本 部 分 采用 编写 抽象 类 实现 的 ， 代 码 如 下 : 


php 
abstract class ConnDemo{ /抽象 类 
Var $host; /主机 名 称 
Var $user; /用 户 名 称 
var $pwd; /用 户 密码 
var $db; /数据 库 名 称 
var $tb; /数据 表 名 称 
var $sql; /SQL 语句 
public function __construct($host, $user,$pwd,$db, $tb){ /| 构造 函数 
S$this -> host = $host; 
S$this -> user = $user; 
S$this -> pwd = $pwd; 
Sthis -> db = 
S$this -> tb = 
S$this -> connect(); 
} 
public function connect| { /连接 方法 
S$this -> conn = $conn; 
S$this -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd) or die ("Connect SQL Server false ); 
mssql_select_db($this -> db,$this -> conn) or die ("Connect Database false"); 
3 
public abstract function update(); /| 抽象 方法 
} 
?> 


(2) 在 conn.php 文件 中 ， 编 写 数据 库 更 新 类 UpdateDemo， 继 承 自 数据 库 连 接 类 并 重 写 抽象 方法 ， 定 义 
SQL0 方 法 和 Update0 方 法 实现 数据 的 更 新 操作 ， 其 代码 如 关键 技术 中 所 示 。 

(3) 新 建 index.php 文件 。 首 先 ， 包 含 conn.php 文件 ， 实 例 化 数据 库 更 新 类 UpdateDemo。 然 后 ， 执 行 查 
询 语 句 ， 循 环 输出 数据 表 中 的 数据 。 接 着 ， 创 建 form 表单 ， 提 交 要 更 新 的 数据 到 本 页 。 最后， 根据 表单 中 提交 
的 数据 ， 调 用 数据 库 更 新 类 UpdateDemo 中 的 方法 执行 更 新 操作 ， 其 关键 代码 如 下 : 


<?php 
if($_POST[sub]){ / 单 击 按钮 
if($_POSTI[check] = ""){ 1/ 判断 单 选 按钮 是 否 被 选中 
echo "<script>alert( 请 选择 要 更 新 的 字段 名 称 ');location.href='index.php?id=1';</script>"; /JavaScript 提示 
Jelse{ 
if($_POST[te] == "输入 更 新 内 容 和 图 书 ID 并 用 空格 分 割 "){ 1/ 判断 文本 框 是 否 有 内 容 
echo "<script>alert( 请 书写 更 新 内 容 和 图 书 ID);location.href='index.php?id=1';</script>"; 。 /JavaScript 提示 
Jelse{ 
$array = explode(" ",$_POSTIte]); /字符 串 拆 分 
if(count($array) > 2 | count($array) == 1){ 1/ 判断 拆 分 后 的 数组 长 度 
echo "<script>alert( 文 本 框 输入 内 容 有 误 ');</script>"; JavaScript 提示 
Jelse{ 
if(Ipreg_match("Ad/",$array[1]){ 1/ 判断 拆 分 后 的 ID 是 否 是 数字 
echo "<script>alert( 输 入 的 图 书 ID 不 是 数字 或 不 在 范围 );location.href="index.php?id=1';</script>"; 
Jelse{ 
$str = $_POST[check]; 
$str1 = iconv(utf-8",'gbk',$array[0]); 
$id = $array[1]; 
S$ud -> SQL ($str, $str1,$id); /调用 类 中 方法 并 传递 参数 
S$ud -> update0: /调用 更 新 方法 
} 
} 
} 
让 
} 
?> 
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图 秘笈 心 法 


心 法 领悟 489: 抽象 类 。 
抽象 类 与 普通 的 类 在 形式 上 没有 太 多 的 差别 。 抽 和 象 类 中 必须 存在 至 少 一 个 抽象 方法 ， 其 好 处 在 于 被 其 他 的 
子 类 继承 时 可 以 选择 性 地 执行 其 中 的 一 个 或 多 个 抽象 方法 。 


pr 
超 味 指数 : 伍 宙 全 全 


实例 490 


图 实例 说 明 


分 页 显示 模块 的 页 码 跳 转 方式 有 多 种 ， 比 如 单 击 页 码 跳 转 、 从 下 拉 列 表 中 选择 页 码 实现 跳 转 等 。 或 许 大 多 
数 程序 员 已 经 熟悉 通过 函数 方式 实现 分 页 ， 而 本 例 将 介绍 如 何 通过 ADO 方式 操纵 SQL Server 数据 库 实现 分 页 
显示 。 熟悉 ASP 的 读者 可 能 会 发 现 , 采用 这 种 方式 实现 分 页 与 ASP 通过 记录 集 实现 分 页 的 方式 类 似 。 运 行 本 实 
例 ， 如 图 10.24 所 示 ， 首 先 在 图 中 文本 框 中 输入 要 跳 转 的 页 码 ， 然 后 单 击 “GO” 按 钮 ， 即 可 实现 页 码 跳 转 。 


| csjs 因 
avast8 基 图 节 2007-12-6 56 

JAVA 共 相关 图 区 2007-12-6 Who 56 

JAVA 缮 相关 图 节 2007-12-6 who 56 
JAVAS 相 天 图 书 2007-12-6 who 56 

JAVA 织 相 关 图 节 2007-12-6 who 56 

| 并 有 主题 406 个 每 页 显示 5 个 弟 1 页 / 失 82 页 1234» wm 加 | 


图 10.24 输入 页 码 跳 转 到 指定 页 


图 关键 技术 


为 了 方便 操作 ， 本 实例 将 采用 GET 方法 提交 用 于 输入 页 码 的 表单 ， 这 样 做 的 目的 是 使 通过 单 击 页 码 实现 的 
跳 转 与 通过 在 文本 框 中 输入 页 码 实现 的 跳 转 都 用 $_GETI 进 行 接收 ,否则 还 得 单独 做 一 个 用 $_POSI[ 数 组 接收 提 
交 的 页 码 的 模块 。 通 过 form 表单 完成 页 码 跳 转 的 代码 如 下 : 


<form action="index.php" method="get" name="forml" id="form1"> 
<tr> 


<td width="30"> 
<div align="center"><input type="text" name="page" size="2" class="inputcss" /></div> 

<ltd> 

<td width="40"> 

</td> 
</tr> 
</form> 

图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 ADO 连接 SQL Server 数据 库 ， 其 代码 如 下 : 

<?php 
$conn=new com("adodb.connection"); /创建 记录 集 
$connstr="provider=sqloledb;data source=localhost'uid=sa;pwd=:database=db_database10"; /连接 SQL Server 数据 库 
$conn->open($connstr); /返回 连接 对 象 
?> 


2) 编写 代码 用 于 接收 查询 字符 串 的 值 〈 该 值 代表 要 跳 转 的 页 ) 并 实现 分 页 显示 ， 代 码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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for($ = 1: $1 < $rs->pagecount: $1+4) { 
?> 
<a href="index.php?page=<?php echo $i:?>"><?php echo Si:?></a> 
27 
{ 
for($1=1; $1<=4: $1+1) { 
?> 


<a href="index.php?page=<?php echo $i:?> "><?php echo $i:?></a> 
<2php 
} 


2> 
<a href="index.php?page=<?php if ($rs->pagecount >= $page + 1) echo $page + 1; else echo 1; ?>" title=" 后 一 页 "><font face="webdings"> 8 


<a href="index.php?page=<?php echo $rs->pagecount; ?>" title=" 尾 页 "><font face="webdings"> : </font></a> 


<?php 
} 
?> 
</div> 
</td> 
</tr> 
</table> 


图 秘笈 心 法 

心 法 领悟 490: 表单 提交 的 两 种 方式 。 

提交 表单 可 以 采取 POST 和 GET 两 种 方式 ， 这 两 种 方式 的 区 别 是 : 使 用 POST 方法 提交 的 信息 在 地 址 栏 中 
不 显示 ， 并且 用 $_POSTI] 数 组 接收 提交 的 内 容 。 而 采用 GET 方法 提交 的 信息 在 地 址 栏 中 显示 ， 如 果 提 交 多 个 信 
息 ， 则 信息 之 间 用 “& ”连接 ， 并 且 提交 的 内 容 用 $_GET[ 数 组 进行 接收 。 


SE 局 
实例 49 趣味 指数 : 窗 俩 耸 俩 


图 实例 说 明 


通过 单 击 页 码 跳 转 到 指定 页 ， 是 众多 分 页 方式 中 应 用 最 广泛 的 一 种 ， 通 过 这 种 方式 可 以 浏览 某 一 模块 中 的 
所 有 信息 。PHP 操作 MySQL 数据 库 实 现 分 页 显示 主要 通过 关键 字 limit 实现 ,但 limit 关键 字 只 是 MySQL 数据 
库 的 扩展 部 分 ， 不 能 被 SQL Server 数据 库 识 别 ， 所 以 本 实例 将 采取 一 种 特殊 方式 实现 SQL Server 数据 库 信 息 的 
分 页 展示 。 运 行 本 实例 ， 如 图 10.25 所 示 ， 通 过 单 击 图 中 页 码 超 链接 即 可 实现 不 同 页 之 间 的 跳 转 。 


| “ 汇 定 页 跑 转 | 


于 发 过时 间 E39 ET 
JAV4 关 相关 图 节 2007/ 上 二 月 /6 0:C0 who 56 
肯 日 科技 出 版 的 VB 区 相关 恒 书 [ 90 
也 日 科 接 出 版 的 C# 关 相关 图 节 phk 12 
随 日 科技 出 版 的 PB 基 相关 司 节 2007/+ 二 有 /3 0:00 二 7 
隔日 科技 出 版 的 C++ 关 相关 图 蔬 2007/H+ 二 月 /3 0:C0 lzh 4 
共有 主题 14 个 每 页 显 东 5 个 第 1 页 / 失 3 页 123 


10.25 ”利用 mssql 函数 库 实现 指定 页 跳 转 


图 关键 技术 


本 实例 采用 mssql 函数 库 ， 通 过 面向 过 程 的 方式 实现 数据 的 分 页 输出 ， 其 基本 原理 是 : 在 获取 数据 表 中 总 
的 记录 数 后 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 ， 进 而 实现 分 页 操作 ， 其 关键 代码 代码 如 下 : 
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分 页 变量 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 ， 其 代码 i 
(3) 创建 分 页 超 链接 ， 完 成 数据 的 分 页 显示 ， 其 代码 如 下 : 
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<?php 
include_once ("conn.php"); 
$sql = mssql_query ( "select * from tb_demo07 order by pubtime desc", $conn ); 
$sqll = mssql_query ( "select count(*) as total from tb_demo07", $conn ); 
$infol = mssql_fetch_array ( $sqll ); 
S$total = $infol [total]; 
if ($_GET [page] == "" ||is_numeric ($_GET [page] ) 一 false) { 
$page =1; 
}else{ 
Spage = $_GET [pagel]; 
} 
S$pagesize = 5; 
if ($total % $pagesize == 0) { 
$totalpage = $total / $pagesize; 
}else{ 
$totalpage = ceil ( $total / $pagesize ); 


$1= 1; 
while ( $info = mssql_fetch_array ($sql ) ) { 
($1 > $pagesize * ($page - 1) && $1 <= $pagesize * $page) { 
> 
<tr> 
<td height="25" bgcolor="#FFFFFF"> 


/包含 数 据 库 连接 文件 
/ 哄 行 查询 

/| 统计 记录 数 

/| 获取 查询 结果 集 
/定义 分 页 变量 

/获取 当前 页 码 


/定义 每 页 显示 记录 数 


/循环 输出 查询 结果 


<div align= "left"><?php echo iconv ( gbk， ‘utf-8", $info [title] );?></div> 


</td> 
<td height="25" bgcolor="#FFFFFF"> 


<div align="center"><?php echo iconv ( ‘gbk", ‘utf-8', $info [pubtime] );?></div> 


<ltd> 
<td height="25" bgcolor="#FFFFFF"> 


<div align="center"><?php echo iconv (‘gbk', ‘utf-8", $info [pubuser] );?></div> 


</td> 
<td height="25" bgcolor="#FFFFFF"> 


<div align="center"><?php echo iconv (‘gbk', ‘utf-8", $info [click] ); ?></div> 


<htd> 
</tr> 
<?php 


Si++; 


?> 


设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 完 成 与 SQL Server 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 查 询 指定 数据 表 中 的 数据 ， 并 且 统计 总 的 记录 数 ， 定 义 


<table width="754" border="0" align="center" celipadding="0" cellspacing="0"> 
<tr> 
<td width="338" height="25"> 


去 会 


青 参考 关键 技术 中 的 内 容 。 


<div align="left"> 共 有 主题 <?phpecho $total:?> 个 &nbsp; 每 页 显示 <?php echo $pagesize;?> 个 &nbsp; 第 <?php echo $page;?> 页 / 共 <?php 


echo $totalpage;?> 页 </div> 
</td> 
<td width="346"> 
<div align="right"> 
<?php 
forGSi = 1; $1 <= $totalpage; $1 ++) { 
?> 
<a href="index.php?page=<?php echo $i:?>"><2?php echo $i:?></a> 
<?php 


?> 
<ldiv> 
</td> 
<td width="70">&nbsp;</td> 
<ltr> 
</table> 
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其 frame 框架 的 布局 如 下 : 


<frameset rows="93,*,25" frameborder="0"> 
nes popefrooea type={$conn_type}" name="topwindow" scrolling="no"> 
<frameset cols="200, 
fame sre-"pd_ ephpzoonn 1 type- {$conn, type}" name="leftwindow" frameborder="1"> 
<frameset rows="37,*" frameborder= "0 
<frame src="pd_title.php" name= sn scrolling="no"> 
<frame src="pd_main.php" name="mainwindow" scrolling="auto" frameborder="1"> 


</frameset> 
</frameset> 
<frame src="pd_bottom.php" name="bottomwindow" scrolling="no" frameborder="1"> 
</frameset><noframes></noframes> 


图 设计 过 程 
“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 文件 包括 模板 页 index.html 和 动态 文件 index.php。 
在 index.html 模板 页 中 ， 应 用 框架 技术 设计 网 页 的 布局 。 
在 index.php 文件 中 ， 首 先 包含 Smarty 配置 文件 ， 然 后 创建 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 
pip 


require_once("system/system.inc.php"); /1 调用 配置 文件 
$smarty->assign(conn_type',$_GET[conn_type]); // 设 置 模板 变量 
$smarty->display(index.html); /指定 模板 页 
?> 


图 秘笈 心 法 


心 法 领悟 492: 页 面 框架 。 
所 谓 框 架 是 指 网 页 的 各 部 分 是 相互 独立 的 页 面 ， 通 过 一 个 网 页 组 成 一 个 完整 的 网 页 显示 在 浏览 器 中 ， 重 复出 
现 的 内 容 被 固定 下 来 ， 每 次 浏览 者 发 出 对 网 页 的 请 求 时 ， 只 需 下 载 发 生变 化 的 框架 页 面 ， 其 他 的 页 面 保持 不 变 。 


高 级 上 
[Sm 器 
实例 493 PE 


力 实例 说 明 


网 站 模块 导航 根据 网 站 的 LOG 中 传递 的 参数 进行 跳 转 ， 如 果 LOG 中 传递 的 是 入 门 的 数据 ， 那 么 网 站 模块 
导航 中 将 输出 入 门类 中 的 功能 模块 ， 如 图 10.27 所 示 。 


= 2 2 全 六 [2 
和 Da 有 高 ai。 开发。 中 Bi。 商用 发 。。 高 你 


图 10.27 入 门类 中 功能 模块 展示 


如 果 LOG 中 传递 的 是 开发 的 数据 ， 那 么 网 站 模块 导航 中 将 输出 开发 类 中 的 功能 模块 ， 如 图 10.28 所 示 。 


党 | 氏 | 向 | 于 | 多 3 了 


视频 9 NPV 项 目 心 。。 方 要 中心。 Nh tp 


图 10.28 开发 类 中 功能 模块 展示 
如 果 LOG 中 传递 的 是 应 用 的 数据 ， 那 么 网 站 模块 导航 中 将 输出 应 用 类 中 的 功能 模块 ， 如 图 10.29 所 示 。 


入 | 负 | 和 | 


公寓 深 管 理 。。 关 治 各 灶 。。 需 8) 间 此 。 工具 事 管 理 。。。 百 全 乱 


10.29 ”应 用 类 中 功能 模块 展示 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 1200 例 (第 I 卷 ) 
元 件 2 的 脚本 代码 如 下 : 


on (release) { 

var type=this.loaderinfo.parameters["conn_type"]; 
getURL("pd_left.php?conn_id=10121002&table_name=jszx&zclass_type= 技 术 中 心 &conn_type=type”, "leftwindow", "GET"); 
} 


元 件 3 中 的 脚本 代码 如 下 : 

on (release) { 

var type=this.loaderinfo.parameters["conn_type"]; 
getURL("pd_left.php?conn_id=10127105&table_name=ymzx&class_type= 源 码 管理 &conn_type=type”, "leftwindow", "GET"); 


} 
第 二 项 技术 : 在 超 链接 中 应 用 onMouseOver 和 onMouseOut 事件 调用 JavaScript 脚本 中 的 方法 , 控制 鼠标 滑 
过 超 链接 图 片 时 的 样式 。 超 链接 的 设置 如 下 : 


<a href="pd_leftphp?conn_id=20510111&table_name=study&class_ type= 从 零 开始 " target="leftwindow"><img 
src= "images/accidence/images_01.jpg" border="0" id="Imagel" onMouseOver="MM_swapImage(Imagel', ,images/accidence/images_001.jpg ,1D)” 
onMouseOut="MML_swapImgRestore0 " /></a> 


JavaScript 脚本 中 定义 的 方法 如 下 : 
function MM_preloadImages0 { //v3.0 
var d=document; if(d.images){ if(ld.MM_p) dMM_p=new Array0; 
var ij=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++) 
让 (afi.indexOf(#)I=OJ{ dMM_p 四 =new Image; d-MM._pli++].src=ali];}} 


} 
function MM_swapImgRestore(0 { //v3.0 
Var i,x,a=document.MM_sr; forli=0;a&&i<alength&&(x=a[i])&&x.oSrc:i++) x.src=X.oSrc; 


} 
function MM_findObi(n, d) { //v4.01 
var pii,x; if(ld) d=document; if((p=n.indexOf("?"))>08&&parent.frames.length) { 
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);} 
if(!(x=d[n])&&d.al) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n]; 
for(i=0;!x&&d.layers& &i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document); 
if(lx && d.getElementById) x=d.getElementByld(n); return x; 


} 
function MM_swapImage0 { //v3.0 
var ij=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3) 
if ((x=MM_findObj(ali]))!=null) {document.MM_sr[j++]=x; if(Ix.oSrc) x.oSrc=x.src; x.src=ali+2];} 
} 


图 设计 过 程 
网 站 模块 导航 的 实现 ， 主 要 应 用 到 pd_top.html 和 pd_top.php， 以 及 js 文件 夹 下 的 flashl.js 和 topjs 文件 。 
(1) 创建 pd_top.php 文件 ， 其 主要 功能 是 定义 模板 变量 传递 参数 以 及 指定 模板 页 ， 其 代码 如 下 : 


<?php 

session_start(); /初始 化 SESSION 变量 

require_once 'system/system_inc.php'; /包含 配置 文件 、 数 据 库 连接 、 操 作文 件 
S$smarty->assign(conn_id,$_GET[conn_id]); /定义 模板 变量 传递 参数 
ey (ee /指定 模板 页 


(2) 创建 模板 页 pd_top.html。 首 先 ， 通 过 script 标签 调用 js 脚本 文件 夹 下 的 topjs 和 flashljs 文件 。 然 后， 
定义 JavaScript 脚本 , 执行 flash10 方 法 , 向 FLASH 中 传递 参数 值 。 最 后 , 根据 模板 变量 $conn_id 的 值 进行 判断 ， 
进而 输出 不 同类 别 的 功能 模块 ， 并 为 输出 的 功能 模块 创建 超 链接 ， 链 接 到 pd_left.php 文件 ， 同 时 传递 相应 的 参 
数 ， 其 关键 代码 如 下 


<head> 
‘<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<title>{$conn_type} 编 程 词典 </title> 

</head> 

<link rel="stylesheet’ type="text/css" href="css/link.css"></link> 

@ <script type="text/javascript"” src="js/top.js"></script> 

@ <script src="js/flash1.js"></script> 

@ <body onLoad-"MM_preloadImages(images/criterion/images002jpg)"> 

<div style="padding-top:inherit; width:1009%; height: 93px; background:url (images/images_09.jpg);"> 
<div style="padding-top:inherit; width:171px; height: 93px; floatleft: "> 


<script type="text/javascript"> 
9 flash1({$conn_type}); 
</script> 
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如 果 是 应 用 类 ， 内 容 树 状 导航 中 默认 展示 的 是 “源码 管理 ”功能 模块 的 内 容 ， 如 图 10.34 所 示 。 


所 之 台 吕 
a 可 


Ce 人 ey 二 
旭 10.33 ”开发 类 的 内 容 树 状 导航 图 10.34 应 用 类 的 内 容 树 状 导航 
图 关键 技术 


在 内 容 树 状 导航 中 , 根据 网 站 模块 导航 中 传递 的 参数 值 , 控制 框架 中 topwindow( 网 站 模块 导航 )、leftwindow 
(内 容 树 状 导航 )》 和 mainwindow 〈 内 容 展 示 区 ) 3 部 分 内 容 的 输出 ， 其 应 用 到 的 技术 如 下 : 
(1) switch 条 件 控制 语句 。 

在 pd_left.php 文件 中 ， 通 过 $_GET[ 方 法 获取 网 站 模块 导航 中 参数 conn_id 传递 的 值 ， 并 将 该 值 作为 switch 
语句 执行 的 条 件 ， 与 case 关键 字 指 定 的 值 进行 判断 ， 如 果 相 同 则 执行 相应 的 操作 ， 首 先 ， 将 一 个 模板 页 赋 给 一 
个 模板 变量 。 然 后 ， 通 过 script 标签 向 topwindow 中 的 pd_top.php( 网 站 模块 导航 ) 文件 传递 参数 。 最 后 ， 通 过 
script 标签 向 mainwindow 中 的 pd_main.php (内 容 展 示 区 ) 文件 传递 参数 ， 其 关键 代码 如 下 : 


1 
switch 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 中 指定 的 值 相同 ， 如 果 相同 ， 则 执行 相应 的 操作 
ek 


switch($_GET[conn_id]){ 
case "20510111": /指定 关键 字 
include ‘accidence.php’; /包含 文件 
$smarty->assign(phtml,accidence .html); 1/ 将 模板 文件 的 名 称 赋 给 模板 变量 
/通过 script 脚本 向 指定 的 文件 中 传递 参数 
echo "<script>parent.topwindow.location.href='pd_top.php?conn_id=20510111';</script>"; 
ee “<script>parent.mainwindow.location. href=pd_main.php? conn_id=20510111';</script>"; 
/跳出 循环 
/路 了 吕 分 代码 
(2) 通过 Smarty 中 的 include 函数 在 当前 模板 中 包含 其 他 模板 文件 。 
在 switch 语句 中 ， 将 指定 的 模板 文件 名 称 赋 给 一 个 模板 变量 phtml， 此 时 在 内 容 树 状 导航 的 模板 文件 
pd_left.html 中 ， 获 取 模 板 变 量 phtml 传递 的 值 ， 并 且 将 该 值 作 为 Smarty 中 include 函数 包含 的 模板 文件 。 内 容 
树 状 导航 模板 文件 pd_lefthtml 的 关键 代码 如 下 : 
<script language="javascript” src="js/leftjs"></script> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 
<bod 
<div sec "width: 100%; height: 100%; padding-left:5px; padding-top:5px:"> 
{include file=$phtml} 


</div> 
</body> 


(3) 通过 Smarty 中 的 注册 模板 函数 读 取 指定 文件 。 
(4) 通过 Smarty 中 的 count_characters 和 truncate 方法 统计 和 截取 字符 串 。 
在 入 门类 、 开 发 类 和 应 用 类 的 树 状 导航 菜单 中 ， 都 应 用 了 Smarty 中 的 count_characters 和 truncate 方法 ， 对 
指定 字符 串 的 长 度 进行 统计 和 截取 ， 进 而 判断 数据 属于 几 级 菜单 。 count_characters 和 truncate 方法 在 本 项 目 中 


应 用 的 关键 代码 如 下 : 
{if $subject[id12].8|count_characters—"12" && $subjectlid12].8ltruncate:8:""==Ssubjectfid].8} 
上 述 代码 取 自 developer.html 模板 文件 。 


图 设计 过 程 


在 内 容 树 状 导 航 概述 中 己 经 了 解 ， 内 容 树 状 导航 除 包含 pd_left.php 和 pd_left.html 文件 外 ， 还 包含 入 门 、 开 
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发 和 应 用 3 类 中 的 6 个 文件 。 

(1) 在 pd_left.php 文件 中 ， 获 取 网 站 模块 导航 超 链接 中 传递 的 参数 值 ， 并 且 将 参数 值 赋 给 SESSION 变量 ， 
通过 switch 语句 ， 对 传递 的 参数 值 进行 判断 ， 进 而 控制 框架 中 topwindow (网 站 模块 导航 ) 、leftwindow (内 容 
树 状 导航 ) 和 mainwindow (内容 展 示 区 ) 3 部 分 内 容 的 输出 ， 其 关键 代码 如 下 : 


<?php 

session_start(); /初始 化 SESSION 变量 

if($_GET[conn_id]=="" and $_GET[table_ namel==-""){ /| 判断 conn_id 和 table_name 的 值 为 空 
$_SESSION[conn_id]="20510111"; // 设 置 初始 值 

$_SESSION[table_name]="study"; /设置 数据 库 名 称 

$_SESSION[class_type]=" 从 零 开始 "; 1/ 设置 功 能 模块 

Jelse{ /如 果 不 为 室 ， 则 直接 将 它们 的 值 赋 给 SESSION 变量 


$_SESSION[conn_idj=$_CET[conn_id]; 

$_SESSION[table_name]=$_GETItable_name]; 

$_SESSION[class_type]=$_GET[class_type]; 

} 

require 'system/system.inc.php'; // 包 含 数据 库 连 接 、 操 作 方法 和 Smarty 的 配置 方法 
a 


switch 条 件 控制 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 
中 指定 的 值 相 同 ， 如 果 相同 ， 则 执行 相应 的 操作 

oh 

switch($_GET[conn_id]){ 


case "20510111": /指定 关键 字 
include 'accidence.php' /包含 文件 
$smarty->assign(phtml,accidence.html); /将 模板 文件 的 名 称 赋 给 模板 变量 


/通过 script 脚本 向 指定 的 文件 中 传递 参数 
echo "<script>parenttopwindow.location.href='pd_top.php?conn_id=20510111';</script> ; 
echo "<script>parent.mainwindow.location.href='pd_main.php?conn_id= 20510111';</script>"; 
break; /跳出 循环 

case "20610111": 
include accidence.php'; 
$smarty->assign( phtml,accidence.html); 
echo "<script>parent.mainwindow.location.href='pd_main.php?conn_id= 26010111';</script>"; 
break; 


/省 略 了 部 分 代码 
default: 

include accidence.php'; 

$smarty->assign( phtml',accidence.html); 

echo "<script>parent.topwindow.location.href="pd_top.php?conn_id=20510111';</script>"; echo 
"<script>try{parent.mainwindow.location.href='pd_main.php?conn_id= 20510111';}catch(e) {}</script>"; 

break; 


} 
$smarty->display(pd_lefthtml); /指定 模板 页 
?> 


(2) pd_left.html 模板 文件 中 输出 的 内 容 由 switch 语句 中 定义 的 模板 变量 phtml 的 值 决定 ， 在 pd_lefthtml 
文件 中 应 用 Smarty 中 的 include 函数 包含 由 phtml 指定 的 模板 文件 ， 其 关键 代码 如 下 : 
‘<script language="javascript" src="js/left.js"></script> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 
<div style="width: 100%; height: 100%; padding-left:5px; padding-top:5px;"> 
{include file=$phtml} 
<ldiv> 
(3) 定义 developer.php 文件 ， 获 取 SESSION 变量 中 传递 的 值 ， 执 行 查询 操作 ， 并 将 查询 结果 赋 给 指定 的 
模板 变量 ， 注 册 模 板 函 数 ， 读 取 指 定 的 文件 ， 其 代码 如 下 : 


<?php 
if($_SESSION[conn_id]=="" and $_SESSION[table_name]==""){ ”// 判 断 SESSION 变量 的 值 是 否 为 空 
$conn_id="10127105"; /如果 SESSION 变量 的 值 为 室 ， 则 直接 为 变量 赋值 


$table_name="ymzx"; 

$class_type=" 源 码 管理 "; 

Jelse{ /各 SESSION 变量 不 为 空 ， 将 SESSION 的 值 赋 给 指定 的 变量 
$conn_id=$_SESSION[conn_id]; 

S$table_name=$_SESSION[table_name]; 

$class_type=$_SESSION[class_typel]; 

} 

$smarty->assign("conn_id",$conn_id); /设置 模板 变量 
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10.4 SQL Server 数据 库 的 安全 与 维护 


图 实例 说 明 

数据 库 在 使 用 一 段 时 间 后 ， 时 常会 出 现 因 删 除数 据 而 造成 的 空闲 空间 太 多 的 情况 ， 这 时 就 需要 减少 分 配给 
数据 库 文件 和 事务 日 志文 件 的 空间 ,以 免 浪费 磁盘 空间 。 当 rm 
数据 库 中 没有 数据 时 , 可 以 直接 修改 数据 库 文件 的 属性 以 改 
变 其 占用 空间 , 但 当 数 据 库 中 有 数据 时 , 这样 操 作 就 会 破坏 
其 中 的 数据 ， 因 此 需要 使 用 收缩 的 方式 来 缩减 数据 库 空间 。 
本 实例 实现 将 SQL Server 数据 库 model 的 未 使 用 空间 缩 为 
数据 库 大 小 的 10%。 在 查询 分 析 器 中 的 运行 结果 如 图 10.36 图 10.36 收缩 数据 和 日 志 
所 示 。 
图 关键 技术 

可 以 使 用 DBCC SHRINKDATABASE 命令 来 压缩 数据 库 。 


DBCC SHRINKDATABASE 语句 的 语法 如 下 : 
DBCC SHRINKDATABASE 
( database_n: 


ame [ , target_percent ] 
[, {NOTRUNCATE | TRUNCATEONLY }] 
) 
参数 说 明 : 
database_name: 要 压缩 的 数据 库 名 称 。 
target_percent: 数据 库 压 缩 后 ， 数 据 库 文件 中 所 要 的 剩余 可 用 空间 百分比 。 如 果 指 定 的 百分比 过 大 ， 超 过 
了 压缩 前 未 使 用 的 空间 所 占 的 比例 ， 则 数据 库 不 会 被 压缩 。 另 外 ， 压 缩 后 的 数据 库 不 能 比 数据 库 初 使 设 定 的 容 
量 小 。 
NOTRUNCATE: 在 数据 库 文件 中 保留 所 释放 的 文件 空间 。 如 果 未 指定 ， 将 释放 的 文件 空间 分 配给 操作 系统 。 
TRUNCATEONLY: 将 数据 库 文件 中 的 任何 未 使 用 的 空间 释放 给 操作 系统 ， 并 将 文件 收缩 到 上 一 次 所 分 配 
的 大 小 ， 从 而 减 小 文件 ， 而 不 移动 任何 数据 ， 不 试图 重新 定位 未 分 配 页 的 行 。 选 择 此 项 后 ，target_percentis 选项 
将 无 效 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 查询 分 析 器 中 选择 要 连接 的 数据 库 为 db_database10。 


(3) 在 代码 编辑 区 中 输入 SQL 语句 : 
DBCC SHRINKDATABASE (model, 10) 


(4) 单 击 执行 按钮 器， 执行 本 实例 ， 即 可 将 数据 库 压缩 。 
力 秘笈 心 法 


心 法 领悟 496: 压缩 数据 库 。 


i 0 000 了 CT 
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数据 库 的 负载 越 大 ， 其 运行 速度 就 越 慢 。 读 者 以 后 的 就 业 取向 可 能 是 PHP 程序 员 ， 而 对 于 数据 库 的 优化 ， 
取得 高 效 的 运行 速度 应 该 是 一 位 合格 的 程序 员 所 必 备 的 技术 。 压 缩 数 据 库 就 是 如 何 优化 数据 库 速度 的 第 一 课 。 


实例 497 2 


趣味 指数 : 会 宣言 疹 | 


图 实例 说 明 


本 实例 实现 的 是 将 master 系统 数据 库 中 标识 (ID ) 号 为 1 的 文件 收缩 到 7MB, 运行 效果 图 如 图 10.37 所 示 。 


0 0 Fs i hoster [oo R 行 后 4 天 1 了 


图 10.37 收缩 数据 和 日 志 


图 关键 技术 
使 用 DBCC SHRINKFILE 命令 来 收缩 相关 数据 库 的 指定 数据 文件 或 日 志文 件 大 小 ， 语 法 如 下 : 


DBCC SHRINKFILE 
({ file_name | file id } 


, target_size ] 
, |[, { EMPTYFILE | NOTRUNCATE | TRUNCATEONLY }] 
) 

参数 说 明 : 

file_name: 已 收缩 文件 的 逻辑 名 称 。 

fle id: 要 收缩 文件 的 标识 (ID ) 号 。 若 要 获得 文件 的 ,请 使 用 FILE_ID 函数 或 在 当前 数据 库 中 搜索 sysfiles。 

target_size: 指定 文件 收缩 后 的 大 小 , 以 MB 为 单位 。 如 果 不 指定 此 选项 , SQL Server 将 最 大 限度 地 缩减 文件 。 

EMPTYFILE: 指明 文件 不 再 使 用 ， 将 所 有 此 文件 中 的 数据 移动 到 同一 文件 组 中 的 其 他 文件 中 去 。 执 行 此 命 
令 后 ， 此 文件 就 可 以 用 ALTER DATABASE 语句 删除 了 。 

参数 NOTRUNCATE 和 TRUNCATEONLY 与 DBCC SHRINKDATABASE 命令 中 的 含义 相同 , 请 读者 参见 

实例 496， 这 里 不 再 歼 述 。 


图 设计 过 程 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”， 登 录 名 为 Sa， 密码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 
USE master 
SELECT FILE_ID(master) 
DBCC SHRINKFILE (1, 7) 
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(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 即 可 实现 数据 的 收缩 。 


图 秘笈 心 法 


心 法 领悟 497: 收缩 数据 与 压缩 数据 。 
在 笔者 看 来 ， 收 缩 数 据 与 压缩 数据 ， 在 功能 上 没有 什么 不 同 。 压 缩 数据 是 按 比 例 将 数据 的 物理 内 存 减 小 ， 
而 收缩 数据 是 根据 传 入 参数 将 数据 文件 的 大 小 减少 至 一 定 值 。 


实例 498 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 数 据 库 一 般 都 保存 有 许多 重要 的 数据 信息 ， 这 些 数据 的 丢失 将 会 带 来 很 严重 的 后 果 ， 
所 以 对 系统 数据 库 进行 备份 非常 重要 ， 这 样 便 可 以 在 数据 库 出 现 错误 时 能 够 及 时 地 恢复 数据 库 。 本 实例 介绍 使 
用 SQL 语句 备份 SQL Server 数据 库 的 过 程 ， 并 让 SQL Server 在 完成 备份 的 20% 时 显示 备份 进度 信息 。 


图 关键 技术 


本 实例 使 用 BACKUP DATABASE 语句 ， 完 成 数据 库 、 差 异 式 或 文件 和 文件 组 的 备份 ， 其 简要 用 法 如 下 : 
BACKUP DATABASE { database_name | @database_name_var } 
TO < backup_device > [,...n] 


[WITH 
[BLOCKSIZE = { blocksize | @blocksize_variable } ] 
[[,] NAME = { backup_set_name | @backup_set_name_var } ] 
,] DESCRIPTION = { ‘text' | @text_variable } ] 


DIFFERENTIAL 


FORMAT | NOFORMAT ] 


RESTART] 


[[ 
[[,] 
[[,] 
[[,] {NOUNLOAD|UNLOAD}] 
[[,] 
[[,] 


STATS [= percentage ] ] 


参数 说 明 如 表 10.2 所 示 。 


表 10.2 BACKUP DATABASE 语句 的 参数 说 明 


参数 说 明 
设置 写 入 时 的 数据 区 块 大 小 。 此 值 通常 不 需 设 置 ， 可 以 由 SQL Server 自行 决定 ， 但 若 要 将 备份 
BLOCKSIZE 数据 库 刻 录 到 光盘 上 ， 并 打算 用 光盘 来 进行 还 原 ， 则 需 将 此 值 设 置 为 2048。 若 要 指定 磁盘 的 数 
据 区 块 大 小 ， 必 须 搭配 FORMAT 参数 使 用 
NAME, 表示 备份 结果 集 的 名 称 ， 其 长 度 不 超过 128 个 字符 
DESCRIPTION, 描述 备份 设置 的 文本 ， 最 多 包括 255 个 字符 
表示 仅 备份 上 次 进行 完整 数据 库 备 份 以 来 ， 数 据 所 发 生 的 变化 ， 即 进行 差异 备份 。 差 异 备份 一 
DIFFERENTIAL 般 比 完整 备份 占用 更 少 的 空间 。 对 于 上 一 次 完整 备份 时 备份 的 全 部 单个 日 志 ， 使 用 该 选项 可 以 
不 必 再 进行 备份 
FORMATINOFORMAT | 设置 是 否 先 格式 化 磁盘 
NOUNLOADIUNLOAD | 设置 是 否 要 在 备份 完成 时 退出 磁盘 
指定 SQL Server 重新 启动 一 个 被 中 断 的 备份 操作 。 因 为 RESTART 选项 在 备份 操作 中 断 处 重新 
RESTART 启动 该 操作 ， 所 以 节省 了 时 间 。 若 要 重新 启动 一 个 特定 的 备份 操作 ， 要 重复 整个 BACKUP 语 
名 并 且 加 入 RESTART 选项 。 不 一 定 非 要 使 用 RESTART 选项 ， 但 它 具有 节省 时 间 的 优势 
STATS 表示 在 备份 完 某 一 百分比 数据 之 后 ， 所 要 显示 的 信息 
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图 设计 过 程 


下 面 将 备份 db_database10 数据 库 ， 具 体操 作 步 又 如 下 : 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 : 
BACKUP DATABASE db_sql 
TO disk=E:\MyDataWdb_sql 备份 .bak" 


(3) 单 击 执行 按钮 》， 执 行 备份 。 备 份 后 的 db_database10 数据 
库 被 保存 在 EE 盘 的 SQL Server Data 文件 夹 中 ， 如 图 10.38 所 示 。 


秘笈 心 法 图 10.38 备份 数据 库 文件 

心 法 领悟 498: 备份 数据 库 的 注意 事项 。 

笔者 在 讲解 MySQL 数据 库 备份 时 已 经 说 过 ， 备 份 出 来 的 文件 虽然 已 经 经 过 加 密 处 理 ， 但 是 也 是 将 数据 信 
息 以 近乎 明文 的 方式 展现 给 用 户 ， 存 在 一 定 的 风险 。 


趣味 指数 会 会 请 全 | 


图 实例 说 明 


本 实例 实现 的 是 在 创建 的 命名 备份 设备 上 创建 db_database10 数据 库 的 事务 日 志 备 份 。 事务 日 志 备份 仅 制作 日 志 
文件 的 复 本 。 日 志文 件 备份 本 身 不 能 用 于 还 原 数据 库 。 日 志文 件 在 数据 库 还 原 后 ， 可 将 数据 库 恢 复 到 原始 的 故障 点 。 


图 关键 技术 
本 实例 应 用 的 技术 有 创建 备份 设备 和 应 用 BACKUP BLOG 语句 备份 事务 日 志 。 
1 创建 备份 设备 


备份 设备 是 创建 备份 和 恢复 数据 库 的 前 提 条 件 ， 可 以 将 数据 库 、 事 务 日 志和 文件 备份 到 磁盘 和 磁带 上 。 
备 可 以 分 为 4 种 : 磁盘 设备 、 磁 带 设备 、 物 理 设备 和 人 逻辑 设备 。 

磁盘 设备 、 磁 带 设备 和 物理 设备 在 备份 时 ， 只 要 选择 相应 的 设备 即 可 。 而 逻辑 设备 用 来 标识 物理 设备 的 别 
名 或 公用 名 称 ， 其 名 称 永久 地 存储 在 SQL Server 内 的 系统 表 中 。 使 用 逻辑 备份 的 优点 是 引用 名 称 简单 ， 例 如 ， 
逻辑 设备 名 称 可 以 是 mrsoft_Backupfdw， 而 物理 设备 名 称 则 是 E\SQL Server DatavmrosftMyBackup.bak。 

在 Transact-SQL 语句 中 ， 使 用 sp- addumpdevice 系统 存储 过 程 创 建 备份 设备 ， 语 法 如 下 : 


] 

参数 说 明 : 

device_ type: 备份 设备 的 类 型 。device_type 的 数据 类 型 为 varchar(20)， 没 有 默认 设置 ， 可 以 是 Disk (硬盘 
文件 ) 、Pipe( 命 名 管理 ) 或 Tape〈 磁 带 设备 ) 。 

Logicalname: 备份 设备 的 逻辑 名 称 , 该 逻辑 名 称 用 于 BACKUP 和 RESTORE 语句 中 , 其 数据 类 型 为 sysname， 
没有 默认 值 ， 并 且 不 能 为 NULL。 

Physicalname: 备份 设备 的 物理 名 称 。 物理 名 称 必须 遵照 操作 系统 文件 名 称 的 规则 或 者 网 络 设备 的 通用 命名 
规则 ,并 且 必 须 包 括 完 整 的 路 径 。physical_name 的 数据 类 型 为 nvarchar(260)， 没 有 默认 值 ， 并且 不 能 为 NULL。 
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2. 用 BACKUP LOG 语句 备份 事务 日 志 


执行 BACKUP LOG 语句 备份 事务 日 志 ， 同 时 要 指定 要 备份 的 事务 日 志 所 属 的 数据 库 名 称 、 事 务 日 志 备份 
将 写 入 的 备份 设备 。 其 语法 格式 请 参见 实例 498 中 的 技术 分 析 。 

执行 完整 数据 库 备份 或 差异 数据 备份 期 间 不 能 备份 事务 日 志 , 但 在 运行 文件 备份 的 同时 可 以 备份 事务 日 志 。 
另外 ， 下 列 情况 不 要 备份 事务 日 志 : 

(1) 在 由 于 事务 日 志 包 含 自 上 次 创建 备份 后 数据 库 所 发 生 的 更 改 ， 而 创建 了 数据 库 或 文件 备份 之 前 。 

(2) 事务 日 志 已 被 截断 。 此 时 如 果 要 备份 事务 日 志 ， 必 须 先 创建 数据 或 差异 数据 库 备份 。 


图 设计 过 程 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 ， 创 建 一 个 名 为 mrsoft_Backupfdw 的 逻辑 磁盘 设备 ， 其 物理 路 径 为 
E:\SQL Server Data\mrosftMyBackup.bak。 
SP_ADDUMPDEVICE ‘disk','mrsoft_Backupfdw', E:\SQL Server Data\mrosft(\MyBackup.bak * 
(3) 单 击 执行 按钮 上， 执行 本 实例 ， 其 运行 结果 如 图 10.39 所 示 。 
(4) 在 代码 编辑 区 中 输入 如 下 SQL 语句 ， 用 来 在 创建 的 命名 备份 设备 mrsoft_Backupfdw 上 创建 db_ 
database10 数据 库 的 事务 日 志 备份 。 


BACKUP LOG db_database10 
TO mrsoft_Backupfdw 


GO 
(5) 单 击 执行 按钮 》， 执 行 本 实例 ， 其 运行 结果 如 图 10.40 所 示 。 


1 
有 起 ”设备 已。 


eT 
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TH, 天 要 7 0 To 000 WE 


图 10.39 创建 备份 设备 图 10.40 事务 日 志 备份 
图 秘笈 心 法 


心 法 领悟 499: SQL Server 备份 事务 日 志 的 注意 事项 。 
在 SQL Server 中 备份 db_database10 数据 库 事务 日 志 的 过 程 中 ， 首 先 选择 数据 库 的 故障 还 原 模 式 ， 如 选择 
“完全 ”模式 ， 然 后 单 击 “ 确 定 ”按钮 ， 如 图 10.41 所 示 。 
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图 10.41 db_database10 数据 库 故障 还 原 模式 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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读 ， 但 不 尝试 验证 备份 卷 中 的 数据 结构 。 如 果 备 份 有 效 ， 则 在 SQL Server 2000 中 返回 此 消息 : “备份 集 有 效 "。 


高 级 
趣味 指数 : 请 评 坎 计 


图 实例 说 明 


本 实例 实现 定时 备份 数据 库 ， 并 让 SQL Server 在 备份 完成 20% 时 显示 备份 进度 信息 。 在 查询 分 析 器 中 的 运 
行 结果 如 图 10.43 所 示 。 


backed up 
1 和 
ck 


和 页 大 用 “也 _databacel0' 件 “三 _databazol0， 御 1 
ATABASE a 理 了 “137 枫 ， 7 Re ho 秒 (6.603 i 0 . 


| 到 


光世， CT ON LE 


图 10.43 定时 备份 数据 库 


力 关键 技术 


本 实例 主要 应 用 转换 函数 CONVERT 实现 。 在 将 datetime 数据 转换 为 char 或 varchar 数据 时 ，CONVERT 
的 style 参数 提供 了 各 种 日 期 显示 格式 。 年 份 可 以 显示 为 两 位 或 四 位 数 。 默 认 情况 下 ，SQL Server 将 年 份 显示 为 
两 位 数 ， 若 要 显示 包括 世纪 的 四 位 数 年 份 〈 即 使 年 份 数据 是 使 用 两 位 数 的 年 份 格式 存储 的 ) ， 给 style 值 加 100 
即 可 。 


图 设计 过 程 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 Sa， 密码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


declare @filename varchar(1000) 

set @filename = 

'E\SQL Server Data\fdw.bak'+convert(char(10),getdate(,112) 
backup database db_database10 

to disk = @filename with stats=20 


(3) 单 击 执行 按钮 ， 执 行 本 实例 ， 其 实现 过 程 如 图 10.44 所 示 。 
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， 这些 民 居于 新 据 库 “中 _databasel0” 多 文件 “二 _dat abase10_Data 【位 于 文件 1 上 ) 。 
stabacel0 的 文件， da aa (从 于 文件 1 上) 。 


图 10.44 本 实例 的 实现 过 程 


力 秘笈 心 法 


心 法 领悟 501: 用 style 参数 转换 日 期 。 
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用 style 参数 转换 日 期 的 语句 如 下 : 
SELECT CONVERT(char(12).CETDATEQ.3) 


此 语句 把 当前 日 期 转换 为 样式 3， 即 dd/mm/yy。 


A 
高 级 a" 
| 入 信众 雁 商 ; | 


图 实例 说 明 


本 实例 实现 对 db_database10 数据 库 tb_demoll 用 户 信息 表 中 的 用 户 
名 和 密码 进行 加 密 。 注意 , 在 通过 pwdencrypt0 函 数 对 相同 的 用 户 名 和 密 
码 进行 加 密 后 ， 生 成 的 结果 却 是 不 相同 并 且 是 不 可 逆 的 。 本 实例 的 运行 |， 
结果 如 图 10.45 所 示 。 TREE 


re OTA 

> 下 上 mrfdw 0x01004CTEZB4C120DEE69C42DC51244,，， 

图 关键 技术 3 3 nifay on100D5TE543030E19EDDD30989F8T 
ms Dn] 


本 实例 主要 应 用 加 密 函 数 pwdencrypt0 和 加 密 校 验 函数 pwdcompare0 EP BY Bs Sm PE EEE 4 
了 图 10.45 “对 数据 库 中 数据 进行 加 密 


用 设计 过 各 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 Sa， 密码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 : 
declare @User varchar(100),@Password varchar(100) 
select  @User='mrfdw',@Password='mrgwh' 
-Insert 插入 
Be into dbo.tb_demoll (Up_Name,Up_Password) 


Bo ,Convert(varbinary(256),pwdencrypt(@Password)) 
一 Select 查询 


(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 实现 的 结果 如 图 10.45 所 示 。 
图 秘笈 心 法 

心 法 领悟 502: 加 密 函 数 pwdencrypt0。 
由 于 此 函数 对 插入 的 相同 数据 进行 加 密 后 ， 生 成 的 结果 不 相同 而 且 不 可 逆 ， 是 一 种 非常 安全 的 加 密 手段 ， 
被 广泛 应 用 。 


高 级 
趣味 指数 : 食 俩 合 窗 : 


图 实例 说 明 


在 编写 本 章 目录 时 ， 本 实例 的 内 容 并 未 纳入 编写 计划 之 中 。 但 是 笔者 认为 ， 每 位 用 户 对 SQL Server 数据 库 
的 掌握 程度 不 尽 相 同 ， 为 了 方便 读者 运行 和 学 习 本 章 实例 内 容 ， 避 免 出 现 不 必要 的 操作 失误 ， 特 向 读者 介绍 一 
些 操 作 SQL Server 数据 库 的 细节 内 容 。 本 实例 主要 讲解 如 何 分 离 、 附 加 数据 库 。 
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图 关键 技术 


分 离 数据 库 : 将 数据 库 从 SQL Server 数据 库 中 分 离 出 来 以 复制 数据 库 文 件 。 已 分 离 的 数据 库 将 无 法 使 用 ， 
除非 再 次 将 其 附加 到 SQL Server 中 。 
附加 数据 库 : 是 相对 于 分 离 数据 库 而 言 的 ， 当 数据 库 文件 被 分 离 后 ， 重 新 载 入 到 数据 库 中 。 


图 设计 过 程 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 企 业 管 理 器 ”命令 ， 启 动 企 业 管理 器 。 

(2) 选中 指定 的 数据 库 ， 单 击 鼠 标 右键 ， 选 择 “所 有 任务 ”/“ 分 离 数据 库 ” 命 令 ， 如 图 10.46 所 示 。 

(3) 附加 数据 库 。 选 中 “数据 库 ” 选 项 ， 单 击 鼠标 右键 ， 选 择 “所 有 任务 ”/“ 附 加 数据 库 ” 命 令 ， 如 
定 ”按钮 完成 附加 。 


图 10.46 ”分离 数据 库 图 10.47 ”附加 数据 库 


图 秘笈 心 法 
心 法 领悟 503: SQL Server 数据 库 的 附加 。 


如 果 要 将 其 他 计算 机 上 的 数据 库 文件 转 到 用 户 机 上 , 可 以 在 SQL Server 安装 路 径 的 Date 文件 夹 下 , 复制 或 
前 切 该 数据 库 文件 ， 然 后 将 其 粘贴 到 用 户 机 SQL Server 安装 路 径 的 Date 文件 夹 中 ， 随 即 附加 数据 库 即 可 。 


高 级 | 
趣味 指数 : 会 会 傅 弃 | 


图 实例 说 明 


Excel 是 集 数据 统计 、 数 据 分 析 、 图 表 制 作 、 打 印 等 功能 于 一 身 的 专业 电子 表格 软件 ， 可 以 将 数据 导出 到 
Excel 中 进行 各 种 处 理 。 本 实例 讲解 将 SQL Server 中 db_database10 数据 库 中 的 数据 表 tb_demo10 的 数据 导出 到 
Excel (tb_demo10.xls) 文件 中 的 方法 ， 运 行 结果 如 图 10.48 所 示 。 


加 microseft Ercel ~ ti_aaaalgl -IDIxl 
:到 文件 四 纺 重 四” 视图 WW 扳 和 WD 相 式 CQ) 工具 CD 
“BO OU PW -ex 
Ed 局 到 
a B c | 7 页 | 
1 1 《PHP 开 发 裕 战 宝 78 元 9， 司 
林 2 《PHP 标 准 教程 > 79 元 Si 
3 3 《FHP 网 络 编程 宝 73 元 A 
4 《FHP 克 例 全 典 > 98 元。 HH 


mn 
数字 


图 10.48 Excel (tb_demol0.xls) 文件 中 的 数据 
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力 关键 技术 


本 实例 主要 应 用 xp_cmdshell 函数 和 bcp 实用 工具 实现 功能 。 
(1) xp_cmdshell 函数 。 

xp_cmdshell: 以 操作 系统 命令 行 解释 器 的 方式 执行 给 定 的 命令 字符 串 ， 并 以 文本 行 方式 返回 任何 输出 ， 其 
语法 如 下 : 

xp_cmdshell fcommand_string } [, no_output] 

参数 说 明 : 

'command_string': 在 操作 系统 命令 行 解释 器 上 执行 的 命令 字符 串 。command_string 的 数据 类 型 为 
varchar(255) 或 nvarchar(4000), 没有 默认 值 。command_string 不 能 包含 一 对 以 上 的 双 引号 ， 如 果 所 引用 的 文件 
路 径 或 程序 名 称 中 有 空格 ， 则 需要 使 用 一 对 引号 。 

no_output: 可 选 参数 ， 表 示 执 行 给 定 的 command_string， 但 不 向 客户 端 返回 任何 输出 。 

返回 代码 值 : 0 (成 功 ) 或 1 (失败 ) 。 

(2) bcp 实用 工具 

bcp 实用 工具 是 一 种 命令 提示 符 大 容量 复制 的 实用 工具 ， 它 以 用 户 指定 的 格式 从 操作 系统 文件 或 向 操作 系 
统 文件 复制 。 下 面 以 bcp 实用 工具 用 于 SQL Server 2000 实例 和 数据 文件 之 间 指定 的 格式 复制 数据 为 例 ， 来 介绍 
bcp 实用 工具 中 几 个 重要 的 参数 。 

回 ”Inloutlqueryoutlformat: 指定 大 容量 复制 的 方向 。In 是 指 从 文件 复制 到 数据 库 表 或 视图 ，out 是 指 从 数 
据 库 表 或 视图 复制 到 文件 。 

-c: 使 用 字符 数据 类 型 执行 大 容量 复制 操作 。 

-q: 在 bcp 实用 工具 和 SQL Server 实例 的 连接 中 执行 SET QUOTED_IDENTIFLERSON 语句 。 
-S server_name[/instance_name]: 指定 要 连接 的 SQL Server 实例 。 

-U login_id: 指定 用 于 连接 的 SQL Server 实例 。 

-P password: 指定 登录 ID 的 密码 。 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


EXEC master. .xp_cmdshell "bcp db_databasel0.dbo.tb_demo10 out E:\tb_demo10.xls -c -q -S"localhost” 
-U"sa" -P"" 


(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 运行 结果 如 图 OA 


办 办 办 办 加 


rie Ei| 
3 rr | 
4 IE 
output 王 | 
1 这 但 : 
NL 
村 开始 复制 
FL 
5 已 员 制 了 5 全。 
5 数据 包 的 大 小 【 字 节 】: 4096 
CL 
Bw 习 
口 梧 三 
二 ei RD ater [DUO Ri 有 -9 行 而 Bi 


图 10.49 从 SQL Server 数据 库 导 出 到 Excel 表 中 


力 秘笈 心 法 


心 法 领悟 504: 使 用 xp_cmdshell 函数 的 注意 事项 。 
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请 耐心 等 待 或 者 刷新 重 试 
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连接 数据 库 

操作 Access 数据 库 
Access 数据 库 的 安全 
Access 数据 库 的 综合 运用 
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11.1 连接 数据 库 


如 果 开发 一 个 小 型 网 站 ， 利 用 Access 数据 库 不 仅 方便 操作 、 易 于 维护 ， 更 重要 的 是 可 以 节省 服务 器 资源 ， 
下 面 将 通过 具体 实例 讲解 PHP 操纵 Access 数据 库 的 方法 。 


图 实例 说 明 
本 实例 主要 介绍 PHP 如 何 通过 ADO 方式 连接 Access 数据 库 , 运行 本 实例 如 图 11.1 所 示 , 该 页 面 显 示 的 信 
息 是 从 Access 数据 库 中 检索 出 来 的 ， 从 而 证 明 通过 ADO 方式 连接 数据 库 成 功 。 


mp 
通过 COM 业 连 拉 ACCESS 莹 过 让】 


你 I0 数 据 库 开 发 完全 手册 》 人 民 都 电 出 版 社 
PC 花 网 宝 夭 》 人 民 地 电 出 版 村 


图 11.1 连接 Access 数据 库 


图 关键 技术 


ADO 技术 基于 通用 对 象 模型 (COM) ， 可 提供 多 种 语言 的 访问 技术 。PHP 是 通过 预先 定义 类 com 来 使 用 
ADO 方法 操纵 Access 数据 库 的 ， 该 类 的 详细 说 明 如 下 : 

string com::com string module_name [, string server_name [, int codepage]]) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 。 

Codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP_MACCP、 CP_OEMCP、 CP_SYMBOL、 CP_THREAD_ACP、 CP_UTF7 和 CP_UTF8。 


图 设计 过 程 


(1) 建立 数据 库 连 接 文件 conn.php， 实 现 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
<?php 
$conn = new com("adodb.connection ); 
$connstr="driver={microsoft access driver (*.mdb)}; dbq=". realpath("data/db_databasel1.mdb"); 
$conn->open($connstr); 
?> 
(2) 建立 如 图 11.1 所 示 的 页 面 ， 并 循环 显示 数据 库 中 的 所 有 图 书信 息 ， 代 码 如 下 : 
<?php 
$sql="select * from tb_book"; 
$rs=new com("adodb.recordset ); 
S$rs->open($sql,$conn,1,3); 
‘while(!$rs->eof) 
a 
?> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv(gbk','utf-8',$rs->fields(bookname)->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv (gbk','utf-8',$rs->fields(pub)->value):?></div></td> 
</tr> 
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图 秘笈 心 法 


心 法 领悟 506: ADO 的 相关 了 解 。 

ADO 向 我 们 提供 了 一 个 熟悉 的 、 高 层 的 对 OLE DB 的 Automation 封装 接口 ， 对 那些 熟悉 RDB 的 程序 员 来 
说 ， 可 以 把 OLE DB 比 作 ODBC 的 驱动 程序 。 目 前 ， 虽 然 OLE DB 的 提供 者 较 少 ， 但 微软 正 积极 更 新 该 技术 并 
打算 用 OLE DB 取代 ODBC。 


人 1 


实例 507 


力 实例 说 明 


虽然 Access 是 开发 小 型 项 目的 首选 数据 库 ， 但 是 ， 商 家 不 会 因为 项 目 小 而 不 要 求 其 安全 性 ， 所 以 给 Access 
数据 库 设置 密码 是 十 分 必要 的 。 本 实例 通过 ADO 方式 连接 带 密码 的 Access 数据 库 。 当 密码 错误 时 ， 将 显示 如 
图 11.2 所 示 的 错误 信息 
atal error: Uncaught sxception com exceptior! with nescage "db)Source:¢/b> Wicrocoft OLE DE Provider| 
or 0DBC DriversCbr/) Cb) :Cb> [Microsoft] [ODBC Microsoft Access ei cr] 密码 无 : in 
:\xampp\xampp\htdocs\R\L1\DO2\conn. php:4 Stack trace: #0 F:\xampp\xanpp\htdocs\IR\11\002\conn, php (4): 


om->open[ driver= fmicroso..，) 相 {nain] throm in F:\xampp\rampp\htdocs\IR\11\002\conn. php cn 
ine 4 


图 11.2 连接 Access 数据 库 密码 错误 


图 关键 技术 


本 实例 实现 连接 带 密码 的 Access 数据 库 的 代码 如 下 : 
< 
和 = new com("adodb.connection"); 
$connstr="driver={microsoft access driver (*.mdb)}:Pwd=111; dbq=". realpath("data/db_databasel1.mdb"); 
$conn->open($connstr); 


其 关键 是 在 ADO 中 设置 Pwd 的 参数 值 ， 即 Access 数据 库 的 密码 。 
设计 过 程 二 Wt a x 二 | | 


(1) 设置 Access 数据 库 的 密码 与 操作 其 他 数据 库 不 同 ,必须 “| [党 3 es 
以 独占 方式 打开 数据 库 。 a 
(2) 选择 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 ， 在 打 


习 
开 的 对 话 框 中 设置 密码 和 确认 密码 ， 如 图 11.3 所 示 。 
(3) 建立 网 页 文件 ， 输 入 如 关键 技术 中 所 示 的 代码 。 如 没有 全 了 
| = | 


任何 输出 ， 表 示 连 接 Access 成 功 。 
图 秘笈 心 法 


心 法 领悟 507: 取消 或 更 改 Access 数据 库 的 密码 。 
当 用 户 对 Access 数据 库 进行 维护 时 ,为 了 方便 起 见 ， 可 以 暂时 撤销 Access 数据 库 的 密码 , 方法 是 : 以 独占 
方式 打开 数据 库 ， 输 入 密码 并 进入 数据 库 ， 选 择 “ 工 具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ” 命 令 ， 根据 提示 再 次 输 


图 11.3 设置 并 确认 密码 
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入 密码 ， 单 击 “确定 ”按钮 即 可 。 


11.2 操作 Access 数据 库 


Access 数据 库 是 小 型 项 目 后 台 支持 的 首选 ， 在 相关 的 数据 库 操 作 上 与 其 他 数据 库 有 所 不 同 。 本 节 将 通过 实 
例 详 细 介绍 如 何 操作 Access 数据 库 。 


S i 
高 级 
起 中 指 儿 页 页 


图 实例 说 明 


本 实例 主要 实现 Access 数据 库 信息 的 查询 。 运 行 本 实例 ， 在 文本 框 中 输入 某 学 生 的 学 号 ， 如 果 查 询 到 该 学 
生 的 成 绩 将 该 学 生 的 详细 成 绩 信 息 显示 出 来 ， 如 图 11.4 所 示 。 


Fy ” S) 
入 字号 :0512101 
0912101 小 刘 三 年 一 得 语文 10 
0312101 小 刘 三 年 二 星 代数 22 


不 到 相 科目 : 2 门 


图 11.4 通用 数据 信息 查询 


图 关键 技术 


通过 ADO 方式 建立 与 Access 数据 库 的 连接 已 经 在 前 面 介绍 过 ， 但 建立 完 该 连接 后 并 不 能 对 数据 库 进行 查 
询 、 更 新 等 操作 ， 必 须 先 实例 化 com 类 ， 建 立 记录 集 ， 然 后 通过 open0 方 法 执行 查询 语句 ， 其 关键 代码 如 下 : 


include("conn.php"); // 包 含 数据 库 连接 文件 
S$rs=new com("adodb.recordset"); /建立 记录 集 
$rs->open("select * from tb_score where sno=".$_POST[sno]."",$conn,3,.1); /执行 查询 
图 设计 过 程 

(1) 新 建 conn.php 文件 ， 建 立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 

?php 
ee com("adodb.connection"); 
$connstr="provider=microsoft.jet.oledb.4.0;data source=".realpath("../data/db_databasel1.mdb"); 
ed 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 学 号 提交 到 本 页 ， 在 本 页 中 根据 POST 方法 提交 的 学 号 执行 
查询 操作 ， 查 询 出 符合 条 件 的 数据 ， 并 且 输 出 查询 结果 ， 代 码 如 下 : 


<?php 
if($_POST[submit]!=""){ 
include("conn.php"); 
S$rs=new com("adodb.recordset"); 
$rs->open("select * from tb_score where sno=".$_POST[sno].”™",$conn,3,1):; 
if($rs->eofll $rs->bof){ 
?> 


<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 查找 到 该 学 生成 绩 ! </div> </td> 
</tr> 


<?php 
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图 实例 说 明 


高 级 | 
趣味 指数 ， 请 语 让 育 


如 果 记 录 集 中 的 记录 较 多 ， 用 一 个 页 面 显示 所 有 记录 会 给 用 户 的 浏览 带 来 诸多 不 便 。 为 了 解决 这 个 问题 ， 
可 以 对 数据 库 中 的 数据 进行 分 页 显示 。 运 行 本 实例 ， 如 图 11.5 所 示 。 
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Visual Basic 重 少 宾 总 200 例 可 柜 工 业 出 版 福 
| 图书 #7 各 每 责 旺 东 20ft 第 3 页/ 共 3 页 


2004 三 5 月 407 页 。 ”各 元 | 
2004 生 2 月 460 页 。 ”和 9 元 | 
2004 年 12 月 321 页 ”36 元 | 
2003 宪 9 月 458 页 “48 元 | 
2003 手 9 月 400 页 4 元 | 
2003 征 8 月 460 页 。 ”49 元 | 
2003 年 1 月 358 页 。 ”39 元 | 
W123 加 


11.5 数据 的 分 页 显示 


图 关键 技术 


PHP 利用 COM 类 连接 数据 库 ， 可 以 直接 使 用 类 中 的 数据 成 员 完成 很 多 操作 ， 常 用 的 数据 成 员 如 表 11.3 


所 示 。 
表 11.3 ”记录 集 对 象 常用 数据 成 员 

数据 成 员 说 了 明 
pagesize 设置 分 页 显示 时 ， 记 录 集 对 象 一 页 所 容纳 的 记录 数 
absolutepage 设置 当前 显示 的 为 第 几 页 ， 首 先 应 设置 pagesize 的 值 
bof 检查 当前 记录 集 对 象 所 指 位 置 是 否 为 第 一 条 记录 之 前 
eof 检查 当前 记录 集 对 象 所 指 位 置 是 否 为 最 后 一 条 记录 之 后 
pagecount 显示 记录 集 当 前 页 面 总 数 ， 首 先 应 设置 pageesize 的 值 
movenext 将 记录 和 集 对 象 的 指针 向 下 移动 一 条 


力 设计 过 程 


(1) 建立 数据 库 连接 文件 conn php， 代 码 如 下 

<?php 
$conn = new com("adodb.connection ); 
$connstr="driver={microsoft access driver (*.mdb)}; dbq=". 
realpath("../data/db_databasel1.mdb "); 
S$conn->open($connstr); 

?> 


(2) 根据 接收 到 的 查询 字符 串 的 值 ， 确 定 显示 的 信息 页 ， 代码 如 下 : 


<?php 
include("Conn/conn.php"); 
$sql="select * from tb_bookinfo order by pdate desc"; 
S$rs=new com("adodb.recordset"); 
S$rs->open($sql,$conn,1,3); 
S$rs->pagesize=20; 


// 包 含 数 据 库 连接 文件 conn.php 
/查询 tb_bookinfo 表 中 的 所 有 商品 
/用 com 类 声明 一 个 记录 集 对 象 
/利用 com 类 的 open( 方 法 执行 查询 
/设置 每 页 最 多 显示 20 条 记录 
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if((trim(intval($_GET[page]))=="")|l(intval($_GET [page])>$rs->pagecount) ll(intval($_GET[page])<=0)) { 


Spage=1; 
}else{ // 否 则 使 $page 的 值 为 所 接收 的 查询 字符 串 的 数值 
Spage=intval($_GET[page]); 
} 
if($rs->eof | $rs->bof) { 1/ 判 断 表 中 的 内 容 是 否 为 空 ， 如 果 为 空 则 给 出 提示 
?> 
<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 本 站 暂 无 商品 ! 
</div></td> 
</tr> 
<?php 
jelse{ /不 为 空 则 分 页 显示 数据 
$rs->absolutepage=$page; /设置 当前 显示 页 为 所 接收 的 查询 字符 串 的 值 
$mypagesize=$rs->pagesize; /定义 变量 Smypagesize 用 于 控制 当前 页 的 循环 终止 
while(!$rs->eof && $mypagesize>0) { // 记 录 集 对 象 没有 到 整个 表 尾 并 且 当 前 页 所 要 显示 的 记录 没有 完全 显示 完 ， 则 循环 显示 数据 信息 
?> 
<?php 
$mypagesize—; /| 每 显示 一 条 记录 ， 应 使 $mypagesize 的 值 减 1 
S$rs->movenext; /使 记录 集 指 针 移 到 下 一 条 记录 的 位 置 
1 
} 
?> 


(3) 向 信息 显示 页 面 发 送 查询 字符 串 从 而 实现 商品 信息 的 分 页 显示 ， 代 码 如 下 : 


if($page>=2){ 


<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page=<?php echo $page-1;?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 
} 


if($rs->pagecount<=4){ 
for($i=1;$i<=$rs->pagecount; $i++){ 


?> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $1;?></a> 
<?php 
} 
Jelse{ 
for($i=1;$i<=4;$i++){ 
?> 
<a href="index.php?page=<?php echo $i:?>"><?php echo $i:?></a> 
<?php 
?> 
<a href="index.php?page=<?php 
if($rs->pagecount>=$page+1) 
echo $page+l; 
else 
echo 1; 
?>"title=" 后 一 页 "><font face="webdings"> 8 </font></a> 
<a href="index.php?page=<?php echo $rs->pagecount:?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php 
} 
?> 
</div> 


力 秘笈 心 法 

心 法 领悟 509: 比较 ASP 与 PHP。 

熟悉 ASP 的 读者 可 能 会 发 现 , PHP 利用 COM 类 连接 Access 数据 库 的 思路 与 ASP 用 ADO 方法 连接 数据 库 
的 思路 类 似 ， 同 样 实现 翻 页 的 思路 也 是 类 似 的 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<td height="25" bgcolor="#FFFFFF"><div align="left">&nbsp:<input type="password" name="userpwd" size="22" 

class="inputcss"></div></td> 
</tr> 
<tr> 

<td height="25" colspan="2" bgcolor="#FFFFFF"><div align="center"><input name="submit" type="submit” value=" 登 录 " 
class="buttoncss"></div></td> 

</tr> 
</form> 


(2) 建立 密码 验证 类 。 
(3) 类 的 实例 化 ， 并 实现 用 户 身 份 的 验证 ， 代 码 如 下 : 


$chkl=new chk ($username, $userpwd); 
$chk1->chkuser(); 


图 秘笈 心 法 
心 法 领悟 510: 类 的 实例 化 。 
- 般 情况 下 ， 创 建 一 个 类 后 并 不 能 直接 对 类 中 的 属性 和 方法 进行 引用 ， 必 须 对 类 进行 实例 化 ， 即 创建 一 个 
对 象 。PHP 中 用 new 关键 字 创建 对 象 。 


i 
实例 511 eR 


趣味 指数 : 会合 请 育 | 


图 实例 说 明 


采用 分 栏 的 方式 将 多 张 图 片 同时 显示 在 一 个 页 面 中 , 可 以 
使 页 面 更 加 规整 。 运 行 本 实例 ， 如 图 11.7 所 示 。 


图 关键 技术 


本 实例 实现 图 片 的 分 栏 显示 主要 依靠 标记 变量 $i， 如 果 该 
变量 的 值 能 被 5 整除 则 显示 下 一 行 ( 当 然 这 是 一 栏 显示 5 张 图 
片 的 情况 ， 如 果 一 栏 显示 4 张 图 片 ， 可 以 通过 判断 该 值 能 否 被 4 整除 ， 依 次 类 推 ) 。 注 意 ， 显 示 一 张 图 片 后 应 
使 $i 的 到 全 1， 实 现 该 过 程 的 代码 如 下 : 

$i=l; 


‘while(!$rs->eof){ 
if ($1 % 5=—0){ 


图 11.7 图 片 的 分 栏 显示 


<td height="25"> 
<div align="left"><img src="<?php echo iconv(gbk','utf-8',$rs->fields(address)->value):?>" border="0">&nbsp;</div> 


<?php 


图 设计 过 过 程 


(1) 建立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 


687 
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<?php 
$conn=new com("adodb.connection"); 
$connstr="provider=microsoft.jet.oledb.4.0;data 
source=".realpath("../data/db_databasel1.mdb "); 
$conn->open($connstr); 
?> 


(2) 查询 数据 库 中 要 显示 图 片 的 地 址 并 获得 记录 集 ， 代 码 如 下 : 
$sql="select * from tb image "; 
$rs=new com("adodb.recordset"); 
S$rs->open($sql,$conn,1,3); 


(3) 实现 图 片 的 分 栏 显示 ， 该 部 分 代码 已 经 在 关键 技术 中 给 出 ， 这 里 不 再 袭 述 。 
图 秘 航 心 法 

心 法 领悟 511: 浅 谈 分 栏 显示 。 

所 谓 的 分 栏 显示 ， 就 是 取得 标记 变量 的 值 ， 进 行 一 些 规定 方法 的 运算 ， 当 运算 结果 符合 条 件 时 ， 便 对 标记 
变量 的 对 应 内 容 进行 分 栏 。 其 实 分 栏 操作 只 是 编程 世界 中 的 一 个 小 技巧 ， 是 程序 员 经 验 不 断 积累 的 结果 。 


a yy 


图 实例 说 明 


为 了 让 读者 从 多 个 方向 了 解 和 学 习 Access 数据 库 ， 本 实例 将 利用 ADODB 技术 ， 对 Access 数据 库 进 行 操 
作 ， 使 读者 在 操作 Access 数据 库 方面 ， 又 多 掌握 了 一 种 方法 。 运 行 本 实例 ， 如 图 11.8 所 示 。 


(EET | 


国 书 19 轿 书 名 和 作者 版 社 
3 | PRP 实 成 京 类 | 明日 科技 下限 公司 。 人 民 邮 电 出 版 社 
于 pp 宇 商 天 日 科技 书评 
1 | PHP 网 始 编程】 明日 科技 表 限 公司 ” 人民 邮 电 出 版 社 
2 | PRP 范 询 室 下 | 明日 科技 交 限 公司 ”人民 邮 昌 出 版 社 | 2010-08-12 00: ffx 站 


图 11.8 插入 图 书信 息 
本 实例 的 关键 点 是 灵活 运用 ADODB 的 相关 函数 ， 包 括 : 
ADONewConnection0 : 连接 数据 库 系 统 。 
PConnect($host, [$user], [$password], [$database]): 持久 化 连接 数据 库 。 
Execute($sql[,$inputarr=false]): 执行 SQL 语句 ， 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 如 果 失 败 则 返 
回 FALSE。 
本 实例 利用 ADODB 实现 连接 Access 数据 库 的 代码 如 下 : 


require_once("../adodb5/adodb.inc.php"); /3I 入 文件 
$conn = ADONewConnection(access): /连接 Access 数据 库 
$conn -> Connect("Driver={Microsoft Access Driver (*.mdb)}: Dbq= F:\AppServ\www\MR\1 1\\data\\db_databasel 1.mdb "); 


有 关 ADODB 技术 的 详细 讲解 ， 读 者 可 以 参考 本 书 第 13 章 的 内 容 。 
图 设计 过 程 


(1) 通过 ADODB 连接 数据 库 ， 代 码 如 关键 技术 中 所 示 。 
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(2) 编写 “显示 信息 ”按钮 ， 单 击 此 按钮 ， 将 输出 Access 数据 库 中 存储 的 所 有 数据 ， 代 码 如 下 : 


<?php 

if($_GET[d] — "1"){ // 单 击 按钮 
$rst = $conn -> execute("select * from tb_demo") or die ("出 错 "); /返回 结果 集 

?> 


<table bgcolor="#80E7EC" width="580px"><tr><td align="center"> 图 书 ID</td><td align="center"> 图 书 名 称 </td><td align="center"> 作 者 </td><td 
align="center"> 出 版 社 </td><td align="center"> 出 版 时 间 </td></tr> 
<?php 
while(!$rst -> EOF){ /1 如果 指针 没有 指向 最 后 一 条 数据 

?> 
<tr> 

<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[0]);?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",S$rst -> fields[1]);?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[2]);?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[3]);?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[4]);?></td> 


<ltr> 
<?php 
Srst -> movenext(; /指针 向 下 移动 
} 
?> 
(3) 编写 表单 ， 通 过 字符 串 拆 分 函数 ， 对 文本 框 内 容 进 行 拆 分 ， 并 执行 插入 操作 ， 代 码 如 下 : 
<?php 
if($_POSTI[sub]){ / 单 击 按钮 
if($_POST[te] 一 "| $_POST[te] == "输入 字段 信息 每 一 项 用 空格 分 割 "){ 1/ 判 断 文本 框 内 容 
echo "<script>alert( 请 在 文本 框 中 输入 内 容 );location.href='index.php?id=1';</script>"; WJavaScriptl 提示 
Jelse{ 
$array = explode(" ",$_POST[te]); /| 拆 分 字符 串 
if(count($array) != 5){ /判断 数组 
echo "<script>alert( 文 本 框 输入 内 容 有 误 ,数据 表 共 5 个 字段 );location.href='index.php?id=1';</script>"; 。 ///JavaScript 提示 
jelse{ 
$a = iconv(utf-8,gbk',$array[0]); /| 转 码 操作 
$b = iconv(utf-8",'gbk',$array[1]); 
$c = iconv(utf-8,gbk',$array[2]); 
$d = iconv(utf-8",'gbk',$array[3]); 
$e = iconv (utf-8",'gbk',$array[4]); 
1/ 判 断 是 否 插入 成 功 
if($conn -> execute("insert into tb_demofid bname ,author ,pub ,date )values(".$a.™,".$b.",".$c.",".$d.",".$e.")"){ 
echo "<script>alert( 插 入 数据 成 功 );location.href='index.php?id=1';</script>"; WJavaScript 提示 
Jelse{ 
echo "<script>alert(SQL 语句 有 误 ， 请 重新 输入 ));location.href='index.php?id=1";</script>"; 
} 
} 
} 
} 
?> 


力 秘笈 心 法 
心 法 领悟 512: Access 数据 库 的 SQL 语句 。 


Access 数据 库 与 MySQL 数据 库 的 SQL 语句 ， 在 更 新 、 删 除 、 查 询 方面 几乎 相同 ， 但 是 在 插入 语句 方面 有 
所 不 同 。 在 编辑 插入 的 insert 语 名 时， 数据 表 字段 必须 由 “` ”包含 。 


实例 513 


趣味 指数 : 催 寅 侠 寅 


图 实例 说 明 


Access 数据 库 虽 然 小 巧 ， 但 是 在 功能 上 并 不 逊 于 其 他 数据 库 ， 进 行 简 单 的 插入 、 删 除 操作 是 很 迅速 的 。 本 
实例 通过 ADODB 连接 Access 数据 库 ， 实 现 删 除 图 书信 息 的 操作 ， 运 行 结果 如 图 11.9 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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ADODB, 全 称 为 Active Data Objects Data Base， 是 存 取 数据 库 所 使 用 到 的 一 组 函数 。 虽 然 PHP 是 构建 Web 
系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函数 一 直 没有 标准 化 ， 不 同 数 据 库 间 的 函数 名 称 、 参 数 差异 很 大 ， 在 更 
换 数据 库 时 ， 会 带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 数据 库 函 数 间 的 差异 ， 以 让 开 
发 者 简单 去 切换 数据 库 ， 这 就 是 ADODB 类 库 。 有 关 其 详细 的 讲解 请 读者 参考 本 书 第 13 章 。 


11.3 Access 数据 库 的 安全 


数据 库 文件 的 安全 非常 重要 ， 尤 其 是 对 于 利用 Access 数据 库 建立 的 小 型 网 站 而 言 ， 用 户 总 是 担心 数据 库 文 
件 会 不 会 被 下 载 、 用 户 名 和 密码 是 否 会 被 他 人 盗 走 、 系 统 是 否 会 被 人 攻击 等 。 下 面 通过 有 具体 实例 来 讲解 网 站 的 
安全 措施 。 


sp 
实例 514 趣味 指数 : 傅 寅 窗帘 | 


力 实例 说 明 

为 防止 用 户 通过 下 载 Access 数据 库 文件 来 达到 窃取 机 密 信息 的 目的 , 可 以 为 Access 数据 库 设置 密码 ， 以 保 
护 数据 ， 这 样 即使 用 户 得 到 数据 库 ， 也 会 因为 没有 密码 而 无 法 查看 数据 库 中 的 内 容 。 运 行 本 实例 ， 对 Access 数 
据 库 设置 密码 的 效果 如 图 11.10 所 示 ， 在 网 站 中 连接 数据 库 的 运行 结果 如 图 11.11 所 示 。 
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图 11.10 设置 数据 库 密码 图 11.11 操作 带 密码 的 Access 数据 库 


图 关键 技术 

本 实例 主要 通过 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 设 置 数 据 库 密码 ”命令 来 设置 Access 数据 库 的 密 
码 ， 同 时 也 可 以 撤销 数据 库 密码 。 

撤销 数据 库 密码 的 过 程 为 选择 Access 菜单 栏 中 的 “工具 ”/“ 安 全”/“ 撤 销 数据 库 密 码 ” 命 令 ， 在 弹出 的 
“撤销 数据 库 密码 ”对话 框 中 输入 设置 时 密码 即 可 。 


痊 提示 : 在 设置 或 者 撤销 Access 数据 库 的 密码 时 ， 必 须 将 数据 库 以 独占 的 方式 打开 。 
图 设计 过 程 
(1) 启动 Access 数据 库 ， 单 击 工具 栏 中 的 本 按钮 ， 弹 出 “打开 ”对 话 杠 ， 选 择 需 要 设置 密码 的 数据 库 文 


件 ， 例 如 bookinfo.mdb， 单 击 “ 打 开 ” 按 钮 右 侧 的 下 三 角 按钮 四， 在 弹出 的 菜单 中 选择 “以 独占 方式 打开 ” 选 
项 ， 则 该 数据 库 文件 将 以 独占 方式 打开 。 
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(2) 选择 主 菜单 上 的 “工具 ”/“ 安 全 ”/ “设置 数 据 库 密码 ”命令 ， 将 弹出 如 图 11.10 所 示 的 对 话 框 ， 在 


该 对 话 框 中 输入 密码 及 密码 验证 码 ， 单 击 “ 确 定 ”按钮 即 可 完成 密码 的 设置 。 


(3) 采用 ADO 方式 连接 加 密 的 Access 数据 库 。 注 意 ， 连 接 加 密 的 Access 数据 库 时 ， 只 需 在 数据 库 连 接 


驱动 中 通过 关键 字 pwd 指定 密码 字符 串 即 可 ， 代 码 如 下 : 
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<?php 
/ 吓 用 PHP 预定 义 类 com 声明 一 个 数据 库 连接 对 象 ， 并 利用 ADO 连接 数据 库 
$conn = new com("adodb.connection"); 


/设置 数据 库 连 接 驱 动 
$connstr="driver={ microsoft access driver (*.mdb)};pwd=mrsoft; dbq=". realpath("data/db bookinfo.mdb ); 
$conn->open($connstr); /调用 com 类 的 open( 方 法 来 执行 上 述 连接 驱动 
?> 
(4) 完成 图 书信 息 分 页 显示 ， 其 关键 代码 如 下 : 
<?php 
include("conn/conn.php"); // 包 含 数据 库 连 接 文 件 conn.php 
$sql="select * from tb_bookinfo order by pdate desc"; 。 /查询 tb_bookinfo 表 中 的 所 有 图 书信 息 
$rs=new com("adodb.recordset"); /用 com 类 声明 一 个 记录 集 对 象 
S$rs->open($sql,$conn,1,3); /利用 com 类 的 open0 方 法 执行 查询 
S$rs->pagesize=10; /设置 每 页 最 多 显示 10 条 记录 
pe nn ll(intval($_GET[pagel)<=0){ 
page=1; 
Jelse{ /否则 使 $page 的 值 为 所 接收 的 查询 字符 串 的 数值 
$page=intval($_CET[page]); 
} 
if($rs->eof | $rs->bof) { 1/ 判断 表 中 的 内 容 是 否 为 宅 ， 如 果 为 宝 则 给 出 提示 
?> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 本 站 暂 无 图 书信 息 ! </div></td></tr> 
<?php 
Jelse{ /不 为 空 则 分 页 显示 数据 
S$rs->absolutepage=$page; 1/ 设置 当前 显示 页 为 所 接收 的 查询 字符 串 的 值 
$mypagesize=$rs->pagesize; // 定 义 变量 $mypagesize 用 于 控制 当前 页 的 循环 终止 
while(!$rs->eof && $mypagesize>0) { // 记 录 集 对 象 没有 到 整个 表 尾 并 且 当 前 页 所 要 显示 的 记录 没有 完全 显示 完 ， 则 循环 显示 数据 信息 
?> 
<td height="20" bgcolor="#FFFFFF"><div align="center"><?php $fields=$rs->fields(pdate);echo $fields->value;?></div></td> 
<td height="20" align="center" bgcolor="#FFFFFF"><?php $fields=$rs->fields(bookpage);echo $fields->value;?>&nbsp; 页 </td> 
<td height="20" align="center" bgcolor="#FFFFFF"><?php $fields=$rs->fields(price);echo $fields->value;?>&nbsp; 元 </td> 
<ltr> 
<?php 
S$mypagesize--; /每 显示 一 条 记录 ， 应 使 Smypagesize 的 值 减 1 
S$rs->movenext; /使 记录 集 指针 移 到 下 一 条 记录 的 位 置 
二 
} 
?> 
<ltr> 
<tr> 


<td width="283" height="25"><div align="left"> 本 站 共有 图 书 <?php echo $rs->recordcount:?> 种 &nbsp; 每 页 显示 <?php echo $rs->pagesize;?> 种 
&nbsp; 第 <?php echo $page;?> 页 / 共 <?php echo $rs->pagecount;?> 页 </div></td> 
<td width="263"><div align="right"> 
<?php 
if($page>=2) { /如 果 当 前 显示 页 的 页 码 大 于 2， 则 显示 首页 和 返回 前 一 页 链接 
?> 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page=<?php echo $page-1:?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 


<?php 

} 

if($rs->pagecount<=4) { // 如 果 总 页 数 小 于 等 于 4， 则 显示 到 所 有 页 的 链接 
for($i=1;$i<=$rs->pagecount:$i++){ 
?> 
<a href="index.php?page=<?php echo $1:?>"><?php echo $i:?></a> 
<?php 
} 
Jelse { 1/ 如 果 总 页 数 大 于 4， 则 显示 到 前 4 页 的 链接 
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for($i=1;$i<=4;$i++) { 


<a href="index.php?page=<?php echo $1:?>"><?php echo $1:7></a> 
<?php 
} 


?> 
<a href="index.php?page=<?php 
if($rs->pagecount>=$page+l) /如 果 到 下 页 链接 的 页 码 大 于 总 页 数 则 显示 第 一 页 


ey ttle=" 后 一 页 "><font face="webdings"> 8 </font></a> 
<a href="index.php?page=<?php echo $rs->pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 


<form name= "forml” method="get" action="index.php"> 

<input type="text" name="page" size="2" class="inputcss"> 

<input name="submit" type="submit" class="buttoncss" value="GO"> 
</form> 


图 秘笈 心 法 


心 法 领悟 514: 支持 跳 转 的 分 页 显示 功能 。 
在 本 实例 中 应 用 面向 过 程 的 技术 编写 分 页 方法 ， 实 现在 不 同 页 面 之 间 的 跳 转 、 上 一 页 和 下 一 页 之 间 的 跳 转 
以 及 跳 转 到 指定 页 面 的 功能 。 


图 实例 说 明 

在 开发 中 小 型 Web 应 用 程序 时 ， 通 常 采用 Access 数据 库 ， 因 为 应 用 Access 数据 库 比 较 方 便 。 在 站 点 上 传 
时 ， 通 常 将 数据 库 文件 和 其 他 文件 一 同上 传 到 网 站 服务 器 中 ， 但 是 这 样 做 是 极 不 安全 的 ， 一 旦 被 用 户 猜测 到 数 
据 库 的 相对 路 径 ， 用 户 在 客户 端 便 可 以 下 载 该 数据 库 文 件 。 例 如 ， 用 户 猜 测 到 某 网 站 的 数据 库 保存 在 站 点 目录 
中 的 db_news.mdb 文件 中 ， 在 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/mr/11/010/data/db_news.php 后 ， 即 可 弹出 
如 图 11.12 所 示 的 文件 下 载 对 话 框 。 


图 11.12 在 客户 端 下 载 数据 库 文件 图 11.13 在 记事 本 中 打开 的 数据 库 文件 


图 关键 技术 


解决 以 上 问题 的 方法 是 将 数据 库 文件 的 扩展 名 由 .mdb 改 为 .php， 即 在 连接 数据 库 时 ， 将 数据 库 文件 指定 
为 .php 文件 即 可 。 此 时 再 打开 该 文件 (db_news.php〉 时 ， 将 会 出 现 如 图 11.13 所 示 的 效果 。 在 默认 情况 下 ， 文 
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件 夹 内 存放 的 文件 的 扩展 名 是 不 显示 的 ， 此 时 无 法 修改 文件 的 扩展 名 。 
图 设计 过 程 


(1) 修改 实例 中 所 用 数据 库 的 扩展 名 ， 将 其 命名 为 db_news.php。 


(2) 新 建 conn 文件 夹 ， 编 辑 conn.php 文件 ， 定 义 Access 数据 库 的 连接 方法 ， 其 代码 如 下 : 
<71 
人 new com( "adodb.connection ); 
$connstr="driver={microsoft access driver (*.mdb)}; dbq=". realpath("data/db_news.php ); 


tom ->0pen($connstr); 
3) 新 建 index.php 文件 ， 包 含 数 据 库 连接 文件 ， 应 用 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 关键 
代码 如 下 : 
<?php 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$sql="select * from tb_news order by pdate desc"; /定义 查询 语句 
$rs=new com("adodb recordset ); /实例 化 类 
$rs->open($sql,$conn,1,3); /执行 查询 操作 
if($rs->eof | $rs->bof){ 1/ 判断 查询 结果 是 否 为 真 
?> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 暂 无 新 闻 信息 ! </div></td></tr> 
?ph 
<ipnp Jelse{ 
while(!$rs->eof){ /循环 输出 查询 结果 
?> 
<tr> 


<td height="20" align="center" bgcolor="#FFFFFF"><div align="center"> 
<?php $fields=$rs->fields(type);echo $fields->value:?> 
</div></td> 
<td height="20" align="left" bgcolor="#FFFFFF"><div align="left"> 
<?php $fields=$rs->fields(newobj):echo $fields->value;?> 
</div></td> 


<?php 
$rs->movenext; 


} 
?> 


国 秘笈 心 法 


心 法 领悟 515: Access 数据 库 的 安全 。 
首先 为 Access 数据 库 设 置 密码 ， 然 后 更 改 Access 数据 库 文件 的 后 级 名 称 ， 通 过 这 两 项 设置 ， 相 信 Access 
数据 库 的 安全 可 以 得 到 一 定 的 保障 


11.4 Access 数据 库 的 综合 运用 


本 节 以 Access 数据 库 为 数据 的 存储 方式 , 开发 一 个 聊天 室 功能 模块 , 通过 这 个 功能 模块 体会 Access 数据 库 
在 完整 项 目 中 的 运用 。 
高 级 
ee he 


实例 516 


力 实例 说 明 
在 本 实例 中 介绍 通过 ADODB 类 库 连接 Access 数据 库 ， 这 里 连接 的 Access 数据 库 是 具有 密码 的 ， 并 且 隐 
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藏 了 Access 数据 库 文件 的 后 级 。 运 行 本 模块 中 的 top.php 文件 ， 就 可 以 测试 
出 数据 库 是 否 连 接 成 功 ， 如 果 连 接 成 功 ， 将 输出 如 图 11.14 所 示 的 页 面 。 


图 关键 技术 
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日 


图 11.14 成 功 连 接 Access 数据 库 


这 里 应 用 ADODB 类 库 连 接 Access 数据 库 ， 并 且 Access 数据 库 设置 了 密码 ， 同 时 对 数据 库 文件 名 称 的 后 
级 进行 了 修改 。 所 以 在 封装 Access 数据 库 的 连接 类 时 ， 必 须 注意 以 下 内 容 : 


要 指定 正确 的 ADODB 类 库 的 调用 路 径 。 


Access 数据 库 的 访问 密码 为 mrsoft。 
Access 数据 库 文件 的 后 级 是 .php。 


图 设计 过 程 


办 办 办 办 加 


由 于 使 用 ADODB 类 库 操作 Access 数据 库 ， 数 据 库 类 型 的 判断 应 该 使 
定义 连接 语句 时 ， 不 要 忘记 Driver 与 (*.mdb) 之 间 的 空格 。 


ado_access。 


(1) 定位 ADODB 类 库 的 位 置 ， 将 其 存储 于 章 目录 11 下 ， 命 名 为 adodb5。 
(2) 定位 Access 数据 库 文件 的 位 置 ， 将 其 存储 于 11\011\data 文件 夹 下 ， 命 名 为 db_messages.php。 
(3) 在 11\011\conn 文件 夹 下 新 建 ConnDB.php 文件 ， 封 装 ADODB 连接 Access 数据 库 类 ， 其 代码 如 下 : 


<?php 

class ConnDB{ 
var $dbType; /人 考据 库 类 型 标识 
Var $host; /人 数据 库 服务 器 地 址 
var $userName; /人 数据 库 服务 器 用 户 名 
var $pwd; /人 数据 库 用 户 密码 
var $dbName; 1/ 要 连接 的 数据 库 名 
var $isDebug; /是 否 显示 调试 信息 
var $connID; /[ 茹 据 库 连接 人 D 


function ConnDB ($dbType = 'mysql, $host, $userName, $pwd, $dbName, $isDebug = false){ 


$this->dbType = $dbType; 


// 为 数据 库 类 型 赋 初 值 


$this->host = $host; // 为 服务 器 地 址 赋 初 值 

$this->userName = $userName; // 为 用 户 名 赋 初 值 

Sthis->pwd = $pwd; // 为 密码 赋 初 值 

$this->dbName = $dbName; 1/ 为 数据 库 名 赋 初 值 
S$this->isDebug = $isDebug; // 为 调试 信息 赋 初 值 
function getConnID 0{ 

require_once '../adodb5/adodb.inc.php’; // 导 入 ADODB 类 库 

$this->connID = NewADOConnection($this->dbType); 。 // 生 成 数据 库 连 接 对 象 


让 ($this->dbType == "mysql || $this->dbType == "mssq1) { // 如 果 为 MySQL 数据 库 或 者 SQL Server 数据 库 


$this->connID->Connect($this->host, $this->userName, $this->pwd, $this->dbName); 


证 (Sthis->dbType == ‘mysql) { 
Sthis->connID->Execute('set names gb2312): 


} 
} elseif ($this->dbType = ‘ado_access) { 


/通过 Connect0 方 法 建立 与 数据 库 连接 
// 设 置 数据 库 编码 
// 如 果 为 Access 数据 库 


/注意 在 连接 Access 数据 库 时 ， 编 写 连接 语句 一 定 要 注意 空格 的 使 用 ， 必 须 严格 执行 ， 否 则 很 可 能 导致 连接 失败 
S$this->connID->Connect(Driver={Microsoft Access Driver (*.mdb)}:;Uid=".$this->userName.’; Pwd=".$this->pwd .; 


Dbq=.realpath($this->dbName).;); 


}else{ 
Teturn false; 
S$this->connID->debug = $this->isDebug; /| 是 否 调试 
Teturn $this->connID; /返回 数据 库 连接 对 象 
} 
function closeConnID 0{ 
@$this->connID->Disconnect0; 1/ 关闭 与 数据 库 的 连接 


} 


} 
(4) 如 果 要 通过 封装 的 ConnDB 类 连接 数据 库 ， 必 须 对 类 进行 实例 化 ， 同 时 向 类 中 传递 参数 ， 最 终 返回 连 
接 标 识 ， 该 操作 被 存储 于 config.inc.php 文件 中 。 在 该 文件 中 完成 数据 库 连接 类 的 实例 化 ， 返 回 连接 的 标识 ， 同 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 关键 技术 


用 户 登录 操作 的 完成 应 用 AdminDB 类 中 的 executeSQL( 方 法 ,在 该 方法 中 可 以 执行 查询 、 添 加 、 更 新 和 删 
除 的 操作 ，AdminDB.php 文件 的 代码 如 下 : 


<?php 
class AdminDB{ 
function executeSQL ($sql, $connID){ 
$sqlType = strtolower(substr(trim($sq]), 0, 6)); /| 提取 SQL 语句 的 类 型 
S$rs = $connID->Execute($sql); / 拱 行 SQL 语句 
if ($sqlType == select) { /如果 是 select 查询 
$arrayData = $rs->GetRows(); /返回 查询 记录 集 
if (count($arrayData) = 0 | $rs 一 false) { /如 果 没 查询 到 或 发 生 错误 
Teturn false; /返回 false 
} else{ / 古 则 
return $arrayData; /版 回 记录 集 
} elseif ($sqlType == ‘insert || $sqlType == update || $sqlType == 'delete) { // 如 果 执 行 插入 、 更 新 或 删除 语句 
return $rs; /返回 语句 执行 状态 ， 即 成 功 返回 true， 失 败 返回 false 
} else{ 
return false; /| 如果 不 是 上 述 查 询 ， 则 返回 false 


bh 已 经 介绍 过 ， 该 类 的 实例 化 操作 同样 存储 于 config.inc.php 文件 中 ， 返 回 对 象 为 gadminDB。 
图 设计 过 程 

(1) 创建 index.php 文件 ， 设 置 聊天 室 的 登录 页 面 ， 通 过 form 表单 将 用 户 登录 信息 提交 到 saveuser.php 文 
件 中 进行 处 理 ， 同 时 创建 验证 用 户 名 是 否 被 占用 的 按钮 ， 调 用 JavaScript 脚本 中 的 open_chknc0 方 法 验证 用 户 名 
是 否 可 用 ， 其 关键 代码 如 下 : 


<?php 
include_once("top.php"); // 包 含 头 文件 


?> 
<form name="form1”method="post" action="saveuser.php" onsubmit="return chkinput(this)"> 


<input type="text" name="usernc" size="15" class="inputcss" maxlength="50"> 
<input type="button" value= "是 否 已 用 ”onClick="open_chknc(forml.usernc.value)”class="buttoncss"> 
<select name="userhead" onchange="javascript:change_head0"> 

<?php 

for($i=0;$1<=11:$1++){ 

?> 


<option value="<?php echo("images/head/".$i.".gif");?>"> 头 像 <?php echo $1?></option> 
<?php 
h 


?> 
‘</select> 
<input type="submit" name="submit" class="buttoncss" value=" 进 入 ">&nbsp;&nbsp; 
<input type="reset" class="buttoncss" value=" 重 写 "> 

</form> 


(2) 在 js/checkjs 文件 的 open_chknc0 方 法 中 ， 调 用 chkusernc.php 文件 ， 验 证 提交 的 用 户 名 是 否 被 占用 ， 
其 关键 代码 如 下 : 


<?php 

$nc=trim($_GET[nc]); 

if($nc==""){ 
echo "请 输入 用 户 昵称 1"; 

Jelse{ 
S$info=$adminDB->executeSQL("select * from tb_puser where usernc=".$nc.™™",$conn); 
if(l$infoj{ 

echo "恭喜 您 ,该 昵称 未 被 占用 !"; 
Jelse{ 

echo "对 不 起 ,该 昵称 已 被 占用 !"; 
} 


?> 
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(3) 新 建 saveuser.php 文件 ， 验 证 登录 用 户 名 是 否 被 占用 ， 如 果 用 户 名 可 用 ， 将 用 户 登 录 信 息 存储 到 指定 
数据 表 中 ， 并 且 跳 转 到 聊天 室 主 页 面 ， 和 否则 提示 用 户 名 不 可 用 ， 或 者 用 户 登录 失败 ， 其 关键 代码 如 下 : 


<?php 
include_once("conn/config.inc.php"); // 包 含 数据 库 连接 、 操 作 类 的 实例 化 文件 
$usernc=trim($_POST[usernc]); /| 获取 提交 的 用 户 名 


$sql=$adminDB->executeSQL ("select * from tb_puser where usernc=".$usernc."",$conn); /验证 用 户 名 是 否 被 占用 
if($sq){ 
echo "<script language='javascript'>alert( 对 不 起 ， 该 昵称 已 被 其 他 用 户 使 用 !):history.back(;</script>"; 

it; 


exit 

Jelse{ 
$logintime=date("Y-m-j H:i:s"); /定义 时 间 
$userhead=$_POST[userhead]; 
$online=1; 
S$ip=getenv("REMOTE_ADDR"); /获取 了 * 
$email=trim($_POST[email]); /| 获取 用 户 提交 的 email 
$mark=0; 
$nowtime=time(); /定义 时 间 截 


$arr=$adminDB->executeSQL ("insert into th_puser (usernc,logintime,ip,email,mark, 
‘$email',$mark','$userhead',$online','$nowtime)",$conn); /执行 用 户 信息 的 添加 操作 
if($ar) { 


nline,nowtime) values ($usernc','$logintime','$ip’, 


$_ SESSION["nc"]=$usernc; /用 户 登 录 成 功 后 将 用 户 名 赋 给 SESSION 变量 
echo "<script>window.location.href='chat.php';</script>"; /处 转 到 聊天 室 主页 
Jelse{ 
echo "添加 失败 1 "; 
} 
} 
?> 


力 秘笈 心 法 
心 法 领悟 517， 使 用 getenv0 函 数 获取 客户 端的 他 地 址 。 
在 本 实例 中 ， 应 用 getenv0 函 数 获 取 客户 端的 全 地 址 ， 其 作用 与 $_SERVER['REMOTE_ADDR'] 是 相同 的 。 


图 实例 说 明 


聊天 室 的 主页 面 由 头 文件 top.php、 尾 文件 bottom.php、 发 布 聊天 信息 chat.php、 聊 天 内 容 listchat.php 和 聊 
天 参与 者 listuser.php 共 5 个 部 分 组 成 ， 其 运行 效果 如 图 11.16 所 示 。 
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jelse{ 
echo $_SESSION [rsnc"]; 
} 
. 


了 
?>"> &nbsp;&nbsp; 
<input type="submit" name="submit" value= "发送 " class="buttoncss" />&nbsp;&nbsp; 
<input name= "reset" type= "reset" class="buttoncss" value=" 重 写 "> 
</form> 
(2) 新 建 saveword.php 文件 ， 将 聊天 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 
<?php 
include_once ("conn/config.inc.php"); // 包 含 配 置 文件 
$fromuser = trim ( $_SESSION ["nc"] ); /获取 登录 用 户 名 称 
$sql = $adminDB->executeSQL ( "select * from tb_puser where usernc=”. $fromuser . "", $conn ); // 判 断 用 户 是 否 存在 
if ($sq) { 
echo "<script>alert( 对 不 起 ,等 待 时 间 过 长 ， 请 重新 登录 !);window.location.href='"logout.php';</script>"; 
exit (0; 
} 
S$touser = $_POST ['touser1]; 
让 ($touser == "所 有 人 ") { 
S$touser = "all 
} 


$content = $_POST [bbs_content]; 
$pubtime = date ( "Y-m-j H:i:s" ); 
$nowtime = time (0; 
$arr = $adminDB->executeSQL ( "insert into tb_message(touser,fromuser,contentpubtime,nowtime) values (‘$touser','$fromuser", '$content', '$pubtime’, 
‘$nowtime')", $conn ); 1/ 执行 信息 的 添加 操作 
if ($arr) { 
echo "<script>window.location.href='chat.php';</script>"; 
}else{ 
echo "添加 失败 !"; 
} 


?> 


(3) 新 建 listuser.php 文件 ， 输 出 聊天 室 当前 的 在 线 用 户 ， 并 通过 JavaScript 脚本 中 的 selectuser0 方 法 调用 


selectuser.php 文件 ， 完 成 聊天 对 象 的 选择 ， 其 关键 代码 如 下 : 
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<script language="javascript"> 
function selectuser(x){ 
parent.form_bbs.touser.value=x; 
parent.form_bbs.touserl.value=x; 
‘window.location.href="selectuser.php?usernc="+x; 
} 
</script> 
<table width="120" border="0" align="center" cellpadding="0" cellspacing="0"> 
<?php 
$array = $adminDB->executeSQL ( "select * from tb_puser where online=1 ", $conn ); 
if (! $array) { 
?> 
<tr><td height="25" colspan="2"><div align="center"> 暂 无 人 登录 </div></td></tr> 
<?php 
}else { 
?> 
<tr onClick= "javascript:selectuser( 所 有 人 ) ”style="cursor: hand"> 
<td height="25" colspan="3" bgcolor="#99CCFF"><div align="center" class="STYLE1"> 发 给 所 有 参与 者 </div></td> 
</tr> 


<?php 
for($i = 0; $i < count ( $array ); $i ++) { /通过 for 循环 输出 数据 库 中 的 数据 
if ($array [$i] [usernc] != $_SESSION ["nc"]) { 
?> 
<tr onClick="javascript:selectuser(<?php echo $array [$i] [1]; ?>)" style="cursor: hand"> 
<td width="25" height="25"><div align="center"><img src="<?php echo $array [$i] [6]; ?>" width="20" height="20" onMouseOver= 
"toolTip(<?php echo $array [$i] [1]; ?>", '<?php echo $array [$i] [3]; ?>", '<?php echo $array [$i] [4]; ?>", '<?php echo $array [$i] [2]; ?>):;" 
‘onmouseout= toolTip(); border=0></div></td> 
<td width="77" height="25"><div align="center"><?php echo $array [$i] [1]; ?></div> 
</td><?php 
} 


} 
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?> 
</table> 
(4) 新 建 selectuser.php 文件 ， 通 过 SESSION 定位 聊天 对 象 ， 代 码 如 下 : 
<2php 
session_start(); /初始 化 SESSION 变量 
unset ($ SESSION[snc]) ; /而 除 SESSION 变量 中 的 值 
$_SESSION["snc"]=$_GET[usernc]; /根据 超 链接 传递 的 变量 值 ， 重 新 为 SESSION 变量 赋值 
echo "<script>window.location.href="listuser.php';</script>"; 
?> 


(5) 新 建 listchat.php 文件 ， 完 成 聊天 信息 的 循环 输出 ， 其 关键 代码 如 下 : 
<table width="500" border="0" align="center" cellpadding="0"cellspacing="0"> 
<?php 
include_once ("function.php"); 
$sql = $adminDB->executeSQL ( "select * from tb_message ", $conn ); 
if ($sql) { 
for($1= 0; Si < count ( $sql ); $1++) { /通过 for 循环 输出 数据 库 中 的 数据 
a [SI] [1 == "all") { 


<tr> 
<td height="20"><img src="images/topic.gif” width="10" height="9"></td> 
<td><div align="left"><font color="#3333FF">[&nbsp;<strong><?php echo $sql [$1] [4]; ?></strong>&nbsp:] &nbsp; 对 
[ &nbsp;<strong> 所 有 人 </strong>&nbsp;] 说 : &nbsp; <?php echo getday ( $sql [$i] [3] ); ?>&nbsp;)</font></div> 


<hd> 
</tr> 
<tr> 
<td height="25" colspan="2"><div align="left">&nbsp;&nbsp;&nbsp;&nbsp;<?php echo unhtml ( $sql [$i] [2] ); ?></div></td> 
</tr> 
<?php 
}else{ 
证 ($_ SESSION ["nc"] 一 $sql [$i] [1] || $_SESSION ["nc"] 一 $sql [$ [4]) { 
?> 
<tr> 


<td width="36" height="20"><img src="images/topic.gif” width="10" height="9"></td> 
<td><div align="left"><font color="#3333FF">[&nbsp;<strong><?php echo $sql [$i] [4]; ?></strong>&nbsp;]&nbsp; 对 
[ &nbsp;<strong><?php echo $sql [$i] [1]; ?></strong>&nbsp;] 说 : &nbsp; (&nbsp;<?php echo getday ( $sql [$i] [3] ); ?>&nbsp;)</font></div> 
</td> 

</tr> 


<td height="25" colspan="2"><div align="left">&nbsp;&nbsp;&nbsp;&nbsp;<?php echo unhtml ( $sql [$i] [2] ); ?></div> 
<ltd> 
</tr> 
<?php 


} 
?> 


</table> 
(6) 新 建 function.php 文件 , 编辑 自 定义 函数 unhtm10 对 聊天 室 中 输出 的 聊天 信息 进行 格式 化 ; 编辑 getday0 
函数 计算 时 间 。 
册 笈 心 法 
心 法 领悟 518: 私 聊 功能 的 实现 。 
PHP 中 实现 私 聊 的 方法 有 多 种 ， 用 SESSION 实现 私 聊 相 对 简单 ， 本 聊天 室 中 私 聊 的 关键 代码 如 下 : 


<?php 
if($_SESSION["nc"]==$info[touser] ||$_SESSION["nc"]==$info[fromuser] ){ 


?> 
En // 显 示 私 聊 内 容 


?> 
上 述 简短 的 代码 说 明了 实现 私 聊 的 原理 ，$_SESSION["nc"] 保 存 的 是 当前 登录 用 户 的 昵称 ，$info[touser] 表 
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$usernc=$_SESSION["nc"]; 
if($usernc!="" || $usernc—'tsoft ){ 
$sql=$adminDB->executeSQL ("delete from th_message ",$conn); 
if($sq){ 
echo "<script>alert( 聊 天 记录 删除 成 功 ! ");window.location.href='chat.php';</script>"; 
} 


Jelse{ 

echo "<script>alert( 不 允许 非法 操作 );window.location.href='admin_login.php';</script>"; 
} 

?> 


(4) 新 建 logout.php 文件 ， 执 行 用 户 或 者 管理 员 的 退出 功能 ， 其 代码 如 下 : 
<?php 
include_once("conn/config.inc.php"); 
$usernc=$_SESSION["nc"]; 
if($usernc=="tsoft"){ 
unset ( $_SESSION['snc] ) ; 
unset ($_SESSION['nc] ) ; 
echo "<script>alert( 退 出 聊天 室 );window.location.href='index.php';</script>"; 


Jelse{ 
$sql=$adminDB->executeSQL("delete from tb_puser where usernc=".$usernc.”™,$conn); 
if($sqD){ 
unset ($ SESSION[snc] ) ; 
unset ($ SESSION[mc] ) ; 
echo "<script>alert( 退 出 聊天 室 );window.location.href='index.php';</script>"; 
} 
} 
入 


力 秘笈 心 法 

心 法 领悟 519: 定时 刷新 聊天 室 的 聊天 信息 和 在 线 列 表 。 

定时 刷新 聊天 室 的 聊天 信息 和 在 线 列表 应 用 的 是 meta 标签 的 http-equiv 属性 和 content 属性 。 通 过 http-equiv 
设置 refresh 执行 刷新 ， 通 过 content 设置 刷新 的 时 间 间 隔 ， 其 代码 如 下 : 


<meta http-equiv="refresh" content="5" /> 
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连接 Oracle 数据 库 
操作 Oracle 数据 库 
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Oracle 数据 的 导入 和 导出 


ld 


ld 


Ph 


Ph 
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12.1 连接 Oracle 数据 库 


本 节 将 介绍 在 PHP 中 如 何 实现 与 Oracle 数据 库 的 连接 ， 这 里 分 别 讲解 通过 Oracle 函数 库 和 ADODB 连接 、 
操作 Oracle 数据 库 。 


连接 Oracle 数据 库 高 级 


实例 520 


力 实例 说 明 


PHP 连接 Oracle 数据 库 的 方法 很 多 ， 这 里 介绍 通过 PHP 中 自 带 的 Oracle 函数 库 来 完成 对 Oracle 数据 库 的 
操作 。 在 本 实例 中 ， 应 用 oci_connect0 函 数 连接 Oracle 数据 库 ， 然 后 应 用 oci_parse0 函 数 执行 查询 语句 ， 最 终 通 
过 oci_fetch_array0 函 数 和 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 运行 结果 如 图 12.1 所 示 。 


| 
A5 明日 人 管理 不 统 [| 
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12.1 oci_connect0 函 数 连接 Oracle 数据 库 


图 关键 技术 


在 PHP 的 Oracle 函数 库 中 提供 有 完成 对 Oracle 数据 库 操作 的 函数 , 这 里 只 对 本 实例 中 应 用 的 函数 进行 详细 
介绍 。 
(1) oci_connect0 函 数 ， 建 立 一 个 到 Oracle 服务 器 的 连接 ， 返 回 一 个 连接 标识 符 ， 其 语法 如 下 : 
Tresource oci_connect( string Username, string password [. string db [. string charset [, int session_mode]]] ) 
oci_connect0 函 数 的 参数 说 明 如 表 12.1 所 示 。 


表 12.1 oci_connect() 函 数 的 参数 说 明 
参数 说 明 

Usemame 必 选 参数 ， 指 定数 据 库 中 的 用 户 名 
password 必 选 参数 ， 指 定数 据 库 中 用 户 的 密码 

可 选 参数 ， 包 含 要 连接 的 本 地 Oracle 的 实例 或 者 在 tnsnames.ora 中 条 目的 名 字 。 如 果 没 有 指定 该 参数 ，PHP 
只 使 用 环境 变量 ORACLE SID (Oracle 实例 ) 或 TWO_TASK (tnsnames.ora) 来 确定 连接 哪 一 个 数据 库 
使 用 Oracle 服务 器 9.2 或 更 高 版 本 时 ， 可 以 指定 charset 参数 ， 被 用 于 新 的 连接 。 如 果 使 用 低 于 9.2 版 本 的 
Oracle 服务 器 ， 本 参数 将 被 忽略 并 以 NLS_LANG 环境 变量 替代 
该 参数 自 版 本 1.1 起 可 用 并 接受 如 下 值 ，OCI_DEFAULT、OCI SYSOPER 和 OCI SYSDBA。 如 果 指 定 
session mode |OCI SYSOPER 或 OCI SYSDBA 其 中 之 一 ，oci_connect0 函 数 将 尝试 使 用 外 部 认证 信息 建立 特权 连接 。 特 
权 连 接 默认 被 禁止 ， 如 果 要 启用 ， 需 要 将 oci8.privileged_connect 设置 为 On 


charset 
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[5 | 
12.2 ADODB 操作 Oracle 数据 库 


[0 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 adodb 类 库 文件 ， 需 要 读者 自行 下 载 


并 复制 到 本 章 的 12 文件 夹 下 ， 并 且 命 名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


图 关键 技术 


使 用 ADODB 连接 数据 库 系 统 应 用 ADONewConnection0 函 数 ; 如 果 选 择 持久 化 连接 数据 库 则 使 用 PconnectO 


函数 ， 如 果 选 择 非 持久 化 连接 则 使 用 ConnectO 函 数 。 


(1) ADONewConnection0 函 数 ， 用 于 连接 数据 库 系 统 ， 其 语法 如 下 : 
ADONewConnection(SdatabaseType) 
参数 $databaseType 表示 要 连接 的 数据 库 系 统 的 名 称 。 例 如 : mysql、oci8 等 。 
(2) PConnectO 函 数 ， 实 现 与 数据 库 持 久 化 连接 。 其 语法 如 下 : 
PConnecttShost [Suser],[Spassword].[Sdatabase]) 
参数 说 明 : 
$host: 数据 库 系 统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 
$password: 数据 库 密码 。 
$database: 使 用 到 的 数据 库 。 
(3) Connect0 函 数 ， 实 现 与 数据 库 非 持久 化 连接 ， 其 语法 如 下 : 
Connect($host.[Suser].[Spassword].[Sdatabase]) 
参数 说 明 : 
$host: 数据 库 系 统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user 数据 库 用 户 名 。 
$password: 数据 库 密码 。 
$database: 使 用 到 的 数据 库 。 


.Cg 技巧 : 持久 化 连接 和 非 持久 化 连接 的 区 别 : 持久 化 连接 不 用 每 次 都 创建 新 连接 ,可 以 增加 程序 的 执行 速度 ， 


但 是 有 些 数 据 库 不 支持 此 函数 ， 那 么 就 需要 使 用 Connect() 函 数 来 替代 PConnectO 函 数 。 
(4) 应 用 execute0 函 数 执行 SQL 语句 ， 应 用 EOF 变量 、while 语句 和 MoveNextO 函 数 完 成 数据 的 循环 输 


出 。 有 关 ADODB 类 库 中 函数 的 详细 讲解 请 参考 第 13 章 。 
图 设计 过 程 


(1) 将 下 载 的 ADODB 类 库 命名 为 adodb5， 存 储 于 12 文件 夹 下 ， 并 且 在 12 文件 夹 下 创建 文件 夹 521 作 
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为 实例 的 根 目录 。 
(2) 在 实例 根 目 录 521 下 创建 conn 文件 夹 ,编写 conn .php 文件 ,应 用 ADONewConnection0 函 数 和 Connect() 


函数 连接 Oracle 数据 库 ， 其 代码 如 下 : 
<?php 


include('../adodb$/adodb.inc.php’); / 厂 入 ADODB 

Sconn =ADONewConnection('oci8): /建立 一 个 oracle 连接 
S$conn->Connect("oracle","system","mrsoft"): /连接 Oracle 数据 库 ， 用 户 名 为 system， 口 令 为 mrsoft 
> 


03) 创建 index.php 文件 ， 通 过 include 语句 包含 数据 库 连 接 文件 ， 完 成 数据 库 中 数据 的 循环 输出 ， 并 且 创 
建 form 表单 ， 将 员工 信息 提交 到 index_ok.php 文件 中 ， 完 成 员工 信息 的 添加 操作 ， 其 关键 代码 如 下 : 


<?php 

if($_GET['conn id]—"1"){ 

include_once 'conn/conn .php': /收入 数据 库 连 接 文件 
$sqlstr = 'select * from tb_user' /sql 查询 语句 

Srst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg 0 ); /| 执行 查询 语句 

while (! Srst->EOF ) { /jwihle 语句 循环 输出 结果 
> 

<tr> 


<td align="center' bgcolor="#FFFFFF"><?php echo $rst->fields [0]:?></td> 
<td align—" "center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst->fields 
<td 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8" "Srst >fields 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312",."utf-8",$rst->fields ['4" 2><htd> 


<ht> 
<?php 
Srst->movenext (); /指针 下 移 
Srst->close (); /| 关闭 连接 
$conn->close (); 
区 
(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 将 员工 信息 添加 到 Oracle 数据 库 中 ， 其 代码 如 下 : 
<?php 
header ( "Content-type: text/html:; charset=utf-8" ); /设置 文件 编码 格式 
include("conmn/conn 多 


if($ 1 POST[name 


ition age,dates) 
b2312".S 放下 和 的 全 ET 全 时 22 pos 


Srst= ee ‘Sconn->erorMsg 0 );: /执行 添加 语句 
Ee "<script>alert(' 信 息 添加 成 功 ! ');window.location.href='index.php?conn_id=1';</script>"; 
入 "<script>alert(' 信 息 添加 失败 ! "):windwo.location.href='index.php'</script>": 

ja 
echo "<script>alert( 请 输入 员工 信息 ! "):windwo.location href='index.php'</script>"; 

} 

> 


力 秘笈 心 


心 法 领悟 521: ADODB 连接 Oracle 数据 库 的 关键 。 
(1) 必须 注意 ， 在 运用 ADONewConnection0 函 数 时 ， 指 定 的 参数 是 oci8。 
(2) 在 Connect0 函 数 中 ， 包 括 3 个 参数 : 第 1 个 参数 是 数据 库 名 称 ， 第 2 个 参数 是 用 户 名 ; 第 3 个 参数 
是 口令 。 
(3) 在 输出 数据 库 中 数据 时 ， 需 要 应 用 iconv0 函 数 对 输出 的 数据 进行 编码 格式 转换 ， 由 原来 的 GB2312 编 
码 转 换 为 utf-8 编码 。 
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图 设计 过 程 

这 里 在 实例 521 的 基础 上 ， 增 加 删除 数据 库 中 数据 的 功能 ， 其 具体 的 方法 如 下 : 

(1) 在 index.php 文件 中 ， 为 输出 的 每 条 数据 添加 一 个 删除 超 链接 ， 链 接 到 delete_ok.php 文件 ， 将 数据 的 
ID 作为 参数 传递 到 delete_ok.php 文件 中 ， 其 关键 代码 如 下 : 

<a href="delete_ok.php?conn_id=<?php echo S$rst->fields [0]: ?>"> 删 除 </a> 

(2) 创建 delete_ok.php 文件 ， 以 超 链接 传递 的 参数 值 为 条 件 ， 执 行 删 除 操作 ， 删 除数 据 表 指 定 的 记录 ， 其 
代码 如 下 : 


<?php 
header ( "Content-type: text/htnl; charset=utf-8" ); // 设 置 文 件 编码 格式 
include("conn/conn.php"); // 包 含 数 据 库 连 接 文件 
$sql="delete from tb_user where id=".$_GET['conn id]."": // 定 义 删除 语句 
Srst = $conn->execute ( $sql ) or die ('error: '. Sconn->errorMsg 0 ); 。“// 执 行 伺 除 语句 
if(Srst){ 
echo "<script>alert( 信息 删除 成 功 ! ):window.location href='index.php':</script>"; 
Jelse{ 
echo "<script>alert( 信息 删除 失败 ! ):windwolocation href='index.php'</script>"; 
} 
> 
秘笈 心 法 


心 法 领悟 522: ADODB 类 库 。 
在 本 章 中 只 是 应 用 ADODB 类 库 连接 、 操 作 Oracle 数据 库 ， 其 实 ADODB 连接 和 操作 任何 数据 库 的 函数 、 
方法 都 是 相同 的 ， 有 关 ADODB 类 库 的 具体 运用 将 在 第 13 章 中 进行 详细 的 讲解 。 


12.2 操作 Oracle 数据 库 


PHP 对 Oracle 数据 库 有 很 好 的 函数 支持 ， 用 户 可 以 通过 这 些 函 数 像 操作 MySQL 数据 库 一 样 操作 Oracle 数 
据 库 。 


高 级 


趣味 指数 : 斌 人 请 讲价 


图 实例 说 明 


本 实例 应 用 PHP 和 Oracle 数据 库 创建 一 个 企业 用 户 管理 模块 ， 实 现 用 户 信息 的 添加 、 查 询 和 更 新 操作 。 运 
行 结 果 如 图 12.4 所 示 。 


| As 明日 人 管理 系统 于 | 局 了 半 加 | 而 | 
的 昌 ID 接 本 有 P [2 司 [| 


六 2: inin! | 进 


1 了 屿 | 区 [ 


oryrieht © 1099-2010 古林 沼 明 日 科技 有 限 公司 


图 12.4 企业 用 户 管理 操作 页 面 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 
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<t> 
<?php 
> 
<tr> 
<td height="35" colspan="5" align=—"right" bgcolor="#FFFFFF"><span class="STYLE1"><?php echo "总 共有 $nrows 记录 !":?> </td> 
tr> 
<?php 
Jelse{ 


> 
<tr><td colspan="5" align="center" bgcolor="#FFFFFF"> 无 数据 </td> 
<> 


时 二 ? 
oci_close($conn); 
?> 


图 秘笈 心 法 

心 法 领悟 525: oci_fetch_all0 函 数 的 应 用 总 结 。 

应 用 oci_fetch_all0 函 数 获取 数据 库 中 总 的 记录 时 ， 在 其 返回 的 数组 中 不 但 包括 数据 表 中 的 数据 ， 而 且 还 包 
括 数 据 表 字段 的 名 称 。 因 此 ， 在 应 用 oci_fetch_all0 函 数 循 环 输出 数据 表 中 的 数据 时 ， 不 必 单 独 定义 数据 表 字 段 
的 名 称 表格 ， 可 以 直接 从 数组 中 获取 ， 同 时 也 不 必 再 应 用 其 他 函数 对 数据 表 中 总 的 记录 数 进行 统计 。 


高 级 


趣味 指数 : 寅 伍 食 办 


实例 526 


图 实例 说 明 


如 果 采 用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 ， 那 么 一 旦 数据 表 中 的 字段 发 生变 化 ， 再 通过 原来 的 表 
格 输出 数据 表 中 的 数据 时 ， 其 运行 效果 将 如 图 12.7 所 示 ， 页 面 输出 内 容 是 不 完整 的 。 


| 


导致 页 面 不 完 
GUO 1000-2010 二 来 用 日 科 技 玫 限 公司 


图 12.7 采用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 


如 果 采 用 动态 读 取 数据 表 中 字段 和 数据 的 方法 就 可 以 避免 图 12.7 所 示 的 问题 ， 无 论 字段 发 生 怎样 的 变化 ， 
在 页 面 中 输出 的 数据 都 是 完整 的 ， 不 必 对 页 面 的 设计 进行 重新 调整 ， 其 运行 效果 如 图 12.8 所 示 。 


i 


融 : 明日 他 旨 东 统 EE 


D NAME POSTION (3 
bE | 种 主页 
对 | ED se 
9 # | EE 


CrP elt 日 1999-3010 声 补 省 明日 科 技 寺 碌 公 司 


图 12.8 ”统计 数据 库 中 数据 的 记录 总 数 
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力 关键 技术 


在 本 实例 中 ， 首 先 应 用 oci_num fields0 函 数 获取 数据 表 中 数据 的 列 数 ， 其 语法 如 下 : 


int oci_num fields( resource statement ) 


该 函数 返回 参数 statement 中 列 的 数目 ， 其 中 参数 statement 为 oci_parse0 函 数 返回 的 标识 符 。 
然后 ， 应 用 oci_field_name0 函 数 动态 获取 数据 表 中 的 字段 信息 ， 其 语法 如 下 : 


string oci field_name( resource statement, int field ) 
该 函数 返回 与 字段 数字 索引 (从 1 开始 ) 相对 应 的 字段 名 。 


最 后 ， 应 用 oci_fetch row0 函 数 完成 数据 库 中 数据 的 循环 输出 ， 以 数字 作 


array Oci fetch_row( resource statement ) 


为 数组 的 索引 ， 其 语法 如 下 : 


该 函数 从 和 指定 的 结果 标识 关联 的 结果 集中 获取 一 行 数据 并 作为 数组 返回 , 如 果 没 有 更 多 行 则 返回 FALSE。 


每 个 结果 的 列 储存 在 一 个 数组 的 单元 中 ， 数 字 索 引 从 0 开始 。 


通过 本 实例 中 介绍 的 函数 循环 输出 数据 库 中 的 数据 ， 可 以 避免 因数 据 表 增加 字段 或 者 减少 字段 ， 而 要 重新 


设计 页 面 的 麻烦 。 


图 设计 过 程 


(1) 新 建 conn 文件 夹 ， 编 写 conn php 文件 ， 定 义 Oracle 数据 库 的 连接 方法 ， 设 置 数据 库 的 编码 格式 为 utf-8。 
(2) 新 建 index.php 文件 ， 首 先 包含 数据 库 连 接 文 件 ， 然 后 应 用 oci_num fields0 和 oci_field_nameO 函 数 以 
及 for 语句 完成 数据 表 中 字段 名 称 的 输出 。 最 后 ， 应 用 oci_fetch_row0 函 数 和 while 语句 根据 数据 表 中 字段 的 列 


数 完 成 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$stmt = oci_parse($conn, "select * from tb_user"): /定义 查询 语句 
oci_execute($stmt); / 预 置 Oracle 语句 
Sncols = oci_num fields($stmt); /获取 数据 表 字 段 的 列 数 
for ($i= 1; $i <= $ncols; $it+) { /| 执行 for 循环 

Sfield name =oci field name($stmt, $i); /获取 字段 的 名 称 


echo "<td bgcolor=#FFFFFF' align='center’ >$field name</td>"; 


oci_free_statement($stmt): /释放 关联 于 Oracle 语句 或 游标 的 所 有 资源 
> 

</t> 
<?php 
$query="select * from tb_user "; // 定 义 SQL 语句 
Sresult=oci_parse($conn,$query): // 预 置 Oracle 语句 
S$r = oci_execute($result, OCI DEFAULT): /执行 查询 语句 
while($row=oci_fetch_row(S$result)){ /while 循环 输出 查询 结果 数组 中 的 数据 


> 
<t> 


<?php 
for (Si= 0: Si < Sncols: Sit+) { /根据 字段 的 列 数 ， 输 出 数据 
echo "<td bgcolor=#FFFFFF' align='center >$row[$i]</td>"; 
} 
> 
</tr> 
php 


} 
oci_close(Sconn): 
> 


力 秘笈 心 法 


心 法 领悟 526: 盘点 本 实例 应 用 的 函数 。 


/关闭 数据 库 


oci field_nameO 函 数 返回 与 字段 数字 索引 《从 1 开始 ) 相对 应 的 字段 名 ， 即 获取 第 一 个 字段 的 名 称 时， 应 
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该 使 用 如 下 格式 : 
Sfield name ”= oci_field_name($Sstmt, 1): /获取 字段 的 名 称 
oci fetch row0 函 数 返 回 数组 ， 数 组 的 数字 索引 从 0 开始 ， 即 获取 oci_fetch_ row0 函 数 返回 数组 中 的 第 一 个 
元 素 值 的 格式 是 : 
Srow=oci_fetch_row(Sresull); 
Srow[O]: /数组 中 的 第 一 个 元 素 
shh 3 克 友 克 家 | 


图 实例 说 明 


前 面 讲解 的 都 是 获取 Oracle 数据 库 中 数据 的 方法 ， 在 本 实例 中 将 介绍 如 何 获取 数据 表 中 字段 的 详细 信息 ， 
运行 结果 如 图 12.9 所 示 。 


SR 于 的 字 眉 信息 
玫 本 名 卫 | 字 彼 清 度 | 地 入 范围 | 。 到 和 关于 。 | 放 入 大 个 | 。 屏 Omk 下 和 天虹 


9 


9 


图 12.9 获取 数据 表 中 字段 的 详细 信息 


图 关键 技术 


本 实例 是 多 个 函数 的 综合 应 用 ， 其 中 包括 : 

oci_num fields0 函 数 ， 获 取 结 果 列 的 数目 。 
oci_field_name() 函 数 ， 获 取 字 段 的 名 称 。 
oci_field_precision0 〇 函数， 获取 字段 的 精度 。 
oci_field_scale0 函 数 ， 获 取 字段 的 范围 。 

oci_field_ typeO 函 数 ， 获 取 字 段 的 数据 类 型 。 
oci_field_size0 函 数 ， 获 取 字 段 的 大 小 。 

oci_field type_raw0 函 数 ， 获 取 字 段 的 原始 Oracle 数据 类 型 。 


图 设计 过 程 


本 实例 综合 运用 Oracle 函数 库 中 操作 数据 表 字 段 的 函数 ， 获 取 数据 表 中 字段 的 各 种 信息 ， 并 且 以 表格 的 形 
式 输出 获取 到 的 数据 ， 其 关键 代码 如 下 : 


<table width="580" border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#339999"> 
<tr><td colspan="6" align="center" bgcolor="#FFFFFF">TB_USER2 表 的 字段 信息 </td></tr> 
<t> 


轿 图 图 图 图 图 加 


<td align="center" bgcolor="#FFFFFF"> 字 段 名 称 </td> 

<td align="center" bgcolor="#FFFFFF"> 字 段 精度 </td> 

<td align="center" bgcolor="#FFFFFF"> 字 段 范围 </td> 

<td align="center" bgcolor="#FFFFFF"> 数 据 类 型 </td> 

<td align="center" bgcolor="#FFFFFF"> 字 段 大 小 </td> 

<td align="center" bgcolor="#FFFFFF"> 原 Oracle 数据 类 型 </td> 
<itr> 


include("conn/conn php"); 

$stmt = oci_parse($conn. "select * from tb_user”): /定义 查询 语句 
oci_execute($stmt); 

Sresult = oci_num fields($stmt): /统计 字段 的 数目 


for ($i= 1; $i < 一 Sresult $it+) { 
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$column name =oci field name($stmt. $i); /获取 字段 名 称 
S$column precision = oci_field_precision($stmt., $i); /获取 字段 的 精度 
S$column scale =oci_field_scale(Sstmt $i); /获取 字段 的 范围 
$column type = oci_field_type($stmt, $i): // 字 有 段 的 数据 类 型 
$column size =oci field size($stmt, $i); /获取 字段 的 大 小 
Scolumn type raw 一 oci field type Taw(Sstmt $i); /获取 字段 的 原始 Oracle 数据 类 型 
?> 
<tr> 

<td align="center" bgcolor="#FFFFFF"><?php echo $column name :?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo $column precision :?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo $column scale :?></td> 


<td align="center" bgcolor="#FFFFFF"><?php echo $column type :?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo $column size ;7></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo $column type raw ;2></td> 
</tr> 


<2php 


} 
oci_free_statement($stmt); /释放 资源 
oci_close(S$conm); /关闭 数据 库 
?> 
</table> 
图 秘笈 心 法 


心 法 领悟 527: 获取 数据 表 中 字段 信息 的 函数 。 


获取 数据 表 中 的 字段 信息 并 不 是 一 项 常用 的 技术 ， 它 只 会 出 现在 一 些 特殊 操作 中 ， 


ed 


在 网 站 的 后 台 管理 系统 中 查看 数据 表 的 结构 等 。 其 中 只 有 oci_num fields 0 和 oci_field_ nameO 函 数 可 能 会 经 常 使 


用 ， 有 关 这 些 函 数 的 详细 讲解 请 参考 PHP 手册 。 


用 户 的 密码 


实例 528 


图 实例 说 明 


高 级 
中 ea | 


在 本 实例 中 ， 介 绍 一 种 可 以 远程 修改 Oracle 数据 库 用 户 密码 的 方法 ， 其 运行 效果 如 图 12.10 所 示 。 


用 户 登 录 Login 


用 户外 ， [GE 


图 12.10 ”修改 Oracle 数据 库 用 户 的 密码 


图 关键 技术 


修改 Oracle 数据 库 用 户 的 密码 应 用 的 是 oci password_ change0 函 数 ， 其 语法 如 下 : 


bool oci_password_change ( resource connection, string usemame. string old_password. string new_password ) 


oci_password_change() 函 数 用 于 修改 用 户 username 的 密码 。 如 果 成 功 返 回 


oci password_ changeO 函 数 的 参数 说 明 如 表 12.7 所 示 。 


TRUE， 失 败 则 返回 


FALSE。 
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表 12.7 oci_password_change() 函 数 的 参数 说 明 


参 。 数 说 有明 
connection | 必 选 参数 ， 数 据 库 连接 成 功 后 返回 的 连接 标识 符 
ae | 必 选 参数 ， 数 据 库 的 用 户 名 
old password | 必 选 参数 ， 旧 密码 


new_password 必 选 参数 ， 新 密码 
图 设计 过 程 
(1) 新 建 数 据 库 连 接 文 件 conn.php， 连 接 用 户 名 为 system， 密 码 为 mrsoft 的 Oracle 数据 库 。 
(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 Oracle 数据 库 的 信息 提交 到 index_ok.php 文件 中 , 在 该 文件 
中 完成 数据 库 用 户 密码 的 更 新 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 Oracle 数据 库 用 户 名 的 信息 ， 应 用 oci_password_change() 
函数 更 新 Oracle 数据 库 用 户 的 密码 ， 其 代码 如 下 : 
eh "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
if($ POSTJuser]'="" ||$ POSTfpass old'"!=""||$ POSTfpass new] 一 S POSTfpass newsTDf 
人 nn /执行 更 新 操作 
echo "<script>alert( 密 码 更 新 成 功 ! '); window.location href='index.php';</script>"; 
4 
人 "<script>alert( 密 码 更 新 失败 ! '); window.location href='index.php';</script>"; 


/关闭 数据 库 


心 法 领悟 528: oci_password_change 0 函数 的 第 二 种 语法 格式 。 
oci_password_change 0 函数 的 第 二 种 语法 格式 如 下 : 

Tesource oci_password_change ( string dbname., string Username. string old_password, string new_password ) 
该 语法 格式 自 版 本 1.1 (OCI8 扩展 库 版 本 ) 起 可 用 。 


实例 529 


力 实例 说 明 


PHP 的 事务 处 理 机 制 可 以 确保 在 操作 过 程 中 遇 到 意外 突然 断 电 、 电 脑 死 机 等 ) 时 数据 不 丢失 。 在 本 实例 
中 ， 应 用 事务 实现 数据 删除 和 添加 同时 操作 ， 并 且 输 出 操作 执行 后 的 结果 ， 如 图 12.11 所 示 。 


村 [ET ETEEE 
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12.11 事务 处 理 机 制 的 应 用 
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力 关键 技术 


在 Oracle 数据 库 中 通过 oci_ commitO 函 数 提交 未 执行 的 事务 处 理 操作 。oci_commit 函数 的 语法 如 下 : 
bool oci_commit( resource connection ) 
oci_commit0 函 数 将 正在 运行 的 事务 中 所 有 未 执行 的 查询 语句 提交 处 理 , 如 果 成 功 返 回 TRUE, 否则 返回 FALSE。 
通过 oci rollback 函数 回 滚 未 提交 的 事务 ， 其 语法 如 下 : 
bool oci rollback( resource connection ) 
oci_rollback0 函 数 回 深 Oracle 连接 connection 上 所 有 未 提交 的 语句 , 如果 成 功 返回 TRUE, 否则 返回 FALSE。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 ， 并 且 设 置 数据 库 编码 格式 为 utf-8。 
(2) 新 建 index.php 文件 。 首 先 ， 执 行 查询 操作 ， 并 且 将 查询 结果 作为 form 表单 元 素 的 初始 值 ， 将 表单 元 
素 中 的 值 提交 到 index_ok.php 文件 中 进行 删除 处 理 。 然 后 ， 再 次 执行 查询 操作 ， 输 出 执行 删除 操作 后 ， 数 据 库 
中 剩余 的 数据 ， 其 关键 代码 如 下 : 
<?php 
include("conn/conn.php"); 
$query="select * from tb_user "; 
Sresult=oci_parse($conn,$query); 


Sr = oci execute($result, OCI DEFAULT): 
while($row=oci_fetch_array($result,OCT RETURN NULLS)){ 
> 


<form id="form1" name="forml" method="post" action="index ok.php"> 
<b> 


<td align="center" valign="middle"><span class="STYLE4"> 
<input name="id" type="text" id="id" size="5" value="<?php echo $row[01;?>" /> 
</span></td> 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name= "user' type="text" id="User" size="8" value="<?php echo $row[11]:;?>" /> 
</span></td> 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name="position" type="text" id="position" size="8" value="<?php echo $row[21:?>" /> 
< 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name="age" type="text" id="age" size="10" value="<?php echo Srowf31:?>" /> 
</span></td> 
<td align="center" valign="middle"> 
<input type="submit" name="Submit" value=" 删 除 " /> 。 </td> 
</tr> 
</form> 
<?php }oci_close($conn);?> 
(3) 创建 index_ok.php 文件 ， 获 取 form 表单 提交 的 数据 ， 首 先 根据 提交 的 ID 值 执行 数据 的 删除 操作 ， 然 
后 定义 添加 语句 将 表单 中 提交 的 数据 添加 到 指定 的 数据 表 中 。 最 后 ， 应 用 oci_commit0 函 数 通 过 事务 提交 数据 ， 
如 果 提 交 执 行 失败 ， 则 应 用 oci_rollback0 函 数 实现 事务 的 回 深 ， 其 代码 如 下 : 


?php 
header ( "Content-type: text/html: charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"): // 包 含 连 接 数 据 库 文件 
if($_POST[' Submit]—true){ 
$query="delete from tb_user where id=".$_POST['id"]."": /定义 删除 语句 
Sresult=0ci_parse($conn.$query): / 预 置 Oracle 语句 
S$r=0ci_execute($result,OCI DEFAULT): /| 执行 删除 操作 
$query="insert into tb_user (id.name.position.age)values(1000'".$_POST['user].".".$_POST['position].".".$_POST['age].")"; 
Sresult=oci_parse($conn.$query); 
oci_execute(Sresult OCI DEFAULT): // 设 置 参 数 为 OCI_DEFAULT， 停 止 语 句 的 自动 提交 
Scommitted = oci_commit($conn): /应 用 事务 提交 数据 
证 (!$committed) { /如 果 事 务 执行 失败 
Serror = oci_error(Sconn): 
echo "事务 执行 失败 : '. $error['message]: 
} 
oci_rollback($conn): /事务 回 滚 
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这 $D{ 
echo "<script> alert(' 删 除 成 功 !"); window -location hreE-'index .php':</scripf> 
| 
oci_close(Sconm): 
} 


图 秘笈 心 法 
心 法 领悟 529: 应 用 事务 处 理 机 制 的 注意 事项 。 
(1) 在 应 用 oci commitO 函 数 之 前 ， 应 该 先 取消 oci_execute0 函 数 的 自动 提交 功能 ， 否 则 事务 将 不 会 被 执行 。 
(2) 当 关 闭 连接 或 脚本 结束 时 事务 会 自动 回 深 。 需 要 明确 地 调用 oci_commit0 函 数 来 提交 事务 ， 或 调用 
oci_rollback0 函 数 来 中 止 事务 。 


实例 530 


图 实例 说 明 


在 操作 Oracle 数据 库 时 ， 循 环 输出 数据 库 中 的 数据 多 数 应 用 的 是 Oracle 数据 库 函 数 。 在 本 实例 中 ， 介 绍 一 
种 特殊 的 输出 数据 的 方法 一 一 将 数据 通过 PHP 变量 进行 输出 ， 其 运行 结果 如 图 12.12 所 示 。 


oc_define_by_name 册 数 的 应 用 


用 户 名 密码 地 址 
酒仙 程序 员 28 
刘 *… 。 部门 理 36 
区 用 部 门 经 理 38 
明日 秘 理 于 
于 程序 员 29 

二 村 省 明日 科技 有 限 公司 


图 12.12 数据 的 循环 输出 


图 关键 技术 


本 实例 循环 输出 数据 库 中 数据 应 用 的 是 oci_define_by_name0 函 数 ， 将 PHP 变量 值 与 SQL 查询 语句 返回 的 
列 进行 绑 定 ， 进 而 直接 通过 PHP 变量 输出 数据 库 中 的 数据 。 

oci_define by _ name 函数， 将 PHP 变量 与 select 语句 中 返回 的 列 进行 绑 定 ， 如 果 定 义 的 变量 不 存在 于 select 
语句 中 ， 并 没有 错误 信息 输出 。 该 函数 的 语法 如 下 : 

‘bool oci_define by_name ( resource statement, string column_name. mixed &variable [, int type] ) 


oci_define by_nameO 函 数 的 参数 说 明 如 表 12.8 所 示 。 
表 12.8 oci_define_by_name() 函 数 的 参数 说 明 


参数 说 明 
statement | 必 选 参数 ， 获 取 的 语句 标识 符 


column name 必 选 参数 ， 指 定 的 字段 名 ， 必 须 大 写 


必 选 参数 ， 输 出 的 变量 


oci_fetch0 函 数 ， 获 取 (对 于 select 语句 ) 结果 中 的 下 一 行 到 内 部 结果 缓冲 区 。 如 果 成 功 则 返回 TRUE， 失 
败 则 返回 FALSE， 其 语法 如 下 : 
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bool oci_fetch( resource statement ) 
在 PHP 5.0.0 之 前 的 版 本 必须 使 用 ocifetchO 蔡 代 本 函数 。ocifetchO 函 数 名 仍然 可 用 ， 为 向 下 兼容 作为 
oci fetchO 的 别名 ， 但 不 推荐 使 用 。 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 Oracle 数据 库 ， 指 定数 据 库 编 码 格式 为 utf-8， 其 代码 如 下 : 


/楼 数据 库 名 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
/如 果 oracle 数据 库 服务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
Se Det commect yet em ee on orles Hor erCoci eesO% 

(2) 新 建 index.php 文件 ， 通 过 PHP 变量 完成 数据 的 循环 输出 。 首 先 ， 包 含 数据 库 连 接 文件 。 然 后 ， 定 义 
SQL 语句 ， 通 过 oci_define_by_name0 函 数 将 SQL 语句 中 查询 出 的 字段 名 称 与 指定 的 变量 进行 绑 定 。 最 后 ， 执 
行 查询 操作 ， 通 过 while 语句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 

<?php 


include("conn/conn.php"); // 包 含 数据 库 连接 文件 
$query="select name, position, age from tb_user "; /定义 SQL 语句 
Sresult=oci_parse($conn.$query): / 预 置 Oracle 语句 
oci_define by name 人 Sresult "NAME", $name); /将 字段 name 与 变量 $name 绑 定 


oci_define_by_name(S$result, "POSITION", Sposition):; 
oci define by name($result, "AGE", $age); 


oci_execute($result); /执行 查询 操作 
while (oci_fetch(Sresult)) { /循环 输出 查询 结果 
> 
<t> 


<td align="center" valign="middle">é&nbsp;</td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo $name:?></span></td> 
<td align="center' valign="middle"><span class="STYLE6"><?php echo $position;?></span></td> 
<td align="center' valign="middle"><span class="STYLE6"><?php echo $age:?></span></td> 
</t> 
oci_free_statement(Sresult); // 肢 放空 间 
oci_close($conn); /关闭 数据 库 
?> 


秘笈 心 法 
心 法 领悟 S30: 应 用 oci_define by_name0 函 数 的 注意 事项 。 
(1) Oracle 使 用 大 写字 母 的 列 名 ， 而 用 户 在 select 中 可 以 用 小 写字 母 ，〈2) 如 果 需 要 定义 一 个 抽象 数据 
类 型 (LOBIROWID/BFILE) ， 必 须 先 用 oci new_descriptorO 函 数 分 配 空间 。 


12.3 ”Oracle 数据库 应 用 


前 面 只 是 讲解 连接 Oracle 数据 库 的 方法 以 及 一 些 简单 的 操作 ,在 本 节 中 将 Oracle 数据 库 应 用 到 实际 的 程序 
开发 中 。 


力 实例 说 明 


本 实例 实现 一 个 管理 员 的 注册 功能 ， 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 将 注册 信息 添加 到 指定 的 
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Oracle 数据 表 中 ， 其 运行 结果 如 图 12.13 所 示 。 


图 12.13 管理 员 注 册 


图 关键 技术 


有 关 ADODB 连接 、 操 作 Oracle 数据 库 的 方法 可 以 参考 实例 521 和 实例 522， 这 里 不 再 袭 述 。 

本 实例 在 完成 管理 员 注册 信息 的 提交 时 ， 应 用 GD2 函数 生成 一 个 数字 验证 码 ， 防 止 数据 的 重复 提交 。 其 中 
验证 码 生成 方法 如 ValidatorCode.php 文件 所 示 : 

<2php 


header('content-type:image/png’); 

srand((double) microtimeO * 1000000): // 定 义 随机 数 种 子 
S$im = imagecreate(65, 25); // 创 建 画布 
imagefill($im, 0, 0, imagecolorallocate($im, 200, 200, 200)); /定义 画布 背景 
SvalidatorCode =S_GET[code]; /获取 验证 码 的 值 
/在 画布 中 输出 验证 码 的 值 


imagestring($im, 8, 9, 2, substr($validatorCode, 0, 1), imagecolorallocate($im., 0, rand(0. 255), rand(0, 255))): 
imagestring($im, 8, 22, 4, substr(SvalidatorCode, 1, 1), imagecolorallocate(Sim. rand(0, 255), 0, rand(0, 255))): 
imagestring($im, 8, 36, 6, substr($validatorCode, 2, 1), imagecolorallocate(Sim, rand(0, 255), rand(0, 255), 0)); 
imagestring($im, 8, 48, 8, substr($validatorCode, 3, 1), imagecolorallocate($im, 0, rand(0, 255), rand(0, 255))): 
/添加 干扰 线 
for ($i= 0; $i< 200; $i++) { 

imagesetpixel($im, rand() % 70, rand() % 30. imagecolorallocate($im, rand(0, 255), rand(0. 255). rand(0. 255))); 


imagepng($im); /生成 png 图 像 
imagedestroyO; /1 销毁 图 像 


图 设计 过 程 
(1) 创建 conn 文件 夹 , 编写 conn.php 文件 , 载 入 adodb.iniphp 文件 。 实现 与 Oracle 数据 库 服务 器 中 Oracle 
数据 库 的 连接 ， 用 户 名 是 system， 口 令 (密码 ) 是 mrsoft， 其 代码 如 下 : 


<?php 

include(.Jadodbs/adodb inc php / 厂 入 ADODB 

S$conn = ADONewConnection('oci8); /建立 一 个 oracle 连接 
S$conn->Connect("oracle","system","mrsoft"); 

> 


(2) 创建 index.php 文件 。 首 先 ， 通 过 script 标签 载 入 js 脚本 文件 。 然后， 创建 form 表单 ， 将 管理 员 注 册 
信息 提交 到 index_ok php 文件 中 ， 同 时 定义 onSubmit 事件 调用 chkinput0 方 法 对 表单 中 元 素 值 进行 验证 。 最 后 ， 
创建 JavaScript 脚本 ， 定 义 方 法 完成 验证 码 的 输出 和 刷新 操作 ， 其 关键 代码 如 下 : 

<script language="javascript" sre="js/check.js"></script> 
<form id="form1" name="form1" method="post" onSubmit="retum chkinput(this)" action="index. ok.php"> 
<table width="480" border="0" align=—"center" cellpadding="0" cellspacing-"0"> 
<td width="87" align="right"> 管 理 员 : </td> 
<td width="380" align—"left"><input name="name" type=—"text" id="name" size="30" /></td> 
</t> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 1200 例 (第 I 卷 ) 


图 12.14 管理 员 登 录 


图 关键 技术 


本 实例 同样 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 在 判断 管理 员 名 称 和 密码 时 ， 应 用 GetArray0 函 数 返 
回 查询 结果 集 数 组 ， 应 用 count0 函 数 统计 数组 中 元 素 个 数 ， 进 而 完成 对 登录 管理 员 的 判断 。 

GetArray([$number_of rows]) 函 数 ， 返 回 从 当前 指针 指向 的 记录 开始 ， 到 ($number_of rows 一 1) 行 的 全 部 
记录 的 数组 。 

参数 $number_of rows 表示 指定 的 记录 行 。 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停 止 。 

countO 函 数 ， 返 回 数组 中 的 单元 数目 ， 用 来 计算 数组 中 值 的 个 数 ， 其 语法 如 下 : 

int count ( mixed array [, int mode]) 

参数 说 明 : 

array: 必 选 参数 ， 指 输入 的 数组 。 

mode: 可 选 参数 ，COUNT RECURSIVE (或 1) 。 如 选中 此 参数 ， 本 函数 将 递归 地 对 数组 计数 ， 对 计算 多 
维 数组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 是 0。 
图 设计 过 程 

(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 实 现 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 添 加 form 表单 ， 将 管理 员 登 录 信息 提交 到 index_ok.php 文件 中 。 

(3) 创建 index_ok.php 文件 ， 根 据 表 单 中 提交 的 管理 员 名 称 和 密码 执行 查询 语句 ， 如 果 返 回 值 大 于 0， 则 
说 明 名 称 和 密码 正确 ， 将 跳 转 到 main php 页 面 ;否则 将 弹出 提示 信息 ， 并 跳 转 到 index.php 页 面 ， 其 代码 如 下 : 

让 二 ("Content-type: text/html; charset=utf-8" ): /设置 文件 编码 格式 

include("conn/conn.php"); 

if($_POST[user]!="" && $_POST['pass]!=""){ 

$sql="select + from tb_admin where name=" iconv("utf-8"."gb2312",$_POST['user'])." and pass=".mdS(iconv("utf-8","gb2312".$_POST[pass])."™" 

Srst = $conn->execute ( $sql ) or die ( 'error: '. $conn->errorMsg 0 ): 


这 count($rst->GetArrayO)>0O)f 
echo "<script>alert( 管 理 员 登录 成 功 ! ):window .location href='main.php':</script>"; 


Jelse{ 
echo "<script>alert( 管 理 员 登 录 失 败 ! window location href='index.php'</script>"; 
} 
Jelse{ 
echo "<scripf>alert(' 请 输入 管理 员 信息 ! ):window-.location href='index.php'</script>"; 
} 
> 


(4) 创建 mainphp 文件 ， 定 义 管理 员 登 录 成 功 后 展示 的 页 面 。 
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图 秘笈 心 法 


心 法 领悟 532: 编码 格式 转换 的 必要 性 。 

在 创建 的 Oracle 数据 库 中 , 数据 的 编码 格式 是 gb2312, 而 程序 页 面 中 的 编码 格式 是 utf-8, 所 以 在 执行 select 
查询 语句 时 ， 在 where 条 件 中 ， 必 须 应 用 iconv0 函 数 对 表单 中 提交 的 用 户 名 和 密码 进行 编码 转换 ， 使 其 与 数据 
库 中 存储 的 数据 编码 统一 ， 这 样 才 可 以 进行 比较 。 否 则 由 于 数据 的 编码 格式 不 同 ， 无 论 输 入 的 用 户 名 和 密码 是 
否 正确 都 不 能 成 功 登录 。 唯 一 一 种 对 数据 编码 格式 没有 限制 的 情况 就 是 数据 中 不 包含 中 文字 符 串 。 


实例 533 


图 实例 说 明 


本 实例 在 实现 管理 员 登 录 功能 的 基础 上 ， 增 加 对 管理 员 数 据 的 更 新 和 删除 功能 。 可 以 对 管理 员 的 名 称 、 密 
码 和 注册 时 间 进 行 更 新 操作 ， 同 时 也 可 以 删除 指定 的 管理 员 数 据 ， 其 运行 结果 如 图 12.15 所 示 。 


注册 时 间 操作 
Paro-ce22 | | 
® [e000023 更 新 


图 12.15 管理 员 数 据 的 更 新 和 删除 


图 关键 技术 


这 里 仍 应 用 ADODB 连接 、 操 作 Oracle 数据 库 。 以 数据 表 中 数据 的 ID 为 条 件 ， 执 行 update 更 新 和 delete 
删除 语句 。 

在 本 实例 中 ， 管 理 员 登 录 成 功 后 ， 应 用 SESSION 会 话机 制 将 登录 的 管理 员 名 称 存储 到 SESSION 变量 中 ， 
通过 这 个 SESSION 来 控制 用 户 的 权限 ， 如 果 是 管理 员 则 可 以 执行 管理 员 数 据 的 更 新 和 删除 操作 ， 否 则 将 给 出 提 
示人 信息， 并 跳 转 到 管理 员 登 录 页 面 ， 其 关键 代码 如 下 : 

<Iphp 


session_start|; /初始 化 SESSION 变量 
header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 

这 $_SESSION[mame']'=""){f / 漳 断 管理 员 的 名 称 是 否 为 空 
include("conn/conn.php"): // 包 含 数据 库 连 接 文件 

这 S$_POST[Submit2] 一 "删除 


Srst= $conn->execute ( $sql ) or die ( ‘error: 1 Sconn->errorMsg 0 ): 
if($rst){ 

echo "<script>alert( 管 理 员 删 除 成 功 ! );window.location href='main php':</script>"; 
Jelse{ 
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echo "<script>alert(' 管 理 员 删除 失败 ! ):windwo location_ href main php'</script>"; 
} 


| 
这 $_POST['Submit] 一 "更 新 "){f 
$sql="update tb_admin set name=" iconv("utf-8"."gb2312".$_POST['name"]).".pass=".md5(iconv("utf-8","gb2312",$_POST['pass]).", 
dates=".$_POST[ dates]." where id=".$_POST['conn id].™; 
Srst = $conn->execute ( $sql ) or die ( ‘error: '. $conn->errorMsg 0 ); 
这 Srsb{ 
echo "<script>alert(' 管 理 员 更 新 成 功 ! )window.location href-main php':</script>": 
Jelse{ 
echo "<script>alert( 管 理 员 更 新 失败 ! ):windwoJocation href="main.php'</script>"; 


} 
} 
iene 不 具有! Jiwindwolocation href-"index.php'</script>"; 
> 

其 中 ,在 管理 员 登 录 的 处 理 页 index_ok.php 中 ， 首 先 初始 化 SESSION 变量 。 在 通过 登录 验证 后 ， 将 登录 用 
户 名 存储 到 SESSION 变量 

在 数据 的 更 新 和 删除 处 理 页 中 ， 首 先 初始 化 SESSION 变量 ， 然 后 ， 通 过 判断 SESSION 变量 的 值 是 否 为 空 
来 决定 当前 用 户 是 否 具有 管理 员 的 权限 。 
图 设计 过 程 

(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 添 加 form 表单 ， 将 管理 员 登 录 的 数据 提交 到 index_ok.php 文件 中 。 

(3) 创建 ndex_ok.php 文件 ， 完 成 登录 用 户 的 验证 操作 。 首 先 ， 初 始 化 SESSION 变量 ， 包 含 数据 库 连 接 
文件 。 然 后 ， 执 行 select 查询 语句 ， 根 据 GetArray0 函 数 返 回 的 数组 元 素 个 数 判断 登录 用 户 的 用 户 名 和 密码 是 否 
正确 ， 如 果 正 确 ， 则 将 用 户 名 赋 给 SESSION 变量 ， 并 且 跳 转 到 main.php 页 面 ， 否 则 ， 给 出 提示 信息 ， 跳 转 到 
index.php 页 面 。 

(4) 创建 main.php 文件 ， 在 form 表单 中 循环 输出 管理 员 数 据 ， 并 且 创 建 管理 员 数 据 的 更 新 和 删除 按钮 ， 
将 数据 提交 到 main_ok.php 文件 完成 更 新 和 删除 操作 ， 其 关键 代码 如 下 : 


<?php 

include_once 'conn/conn .php' // 载 入 数据 库 链接 文件 
$sqlstr = 'select * from tb_admin '; /SQL 查询 语句 

Srst = $conn->execute ( $sqlstr ) or die ('error: '. $conn->errorMsg 0 ); // 执 行 查询 语句 

while (! Srst>EOF ) { /hwihle 语句 循环 输出 结果 


?> 
id="form<?php echo $rst->fields [0]; ?>" name="form<?php echo $rst->fields ['0']; ?>" method="post" action="main_ok.php"> 


3 a ‘center" bgcolor="#FFFFFF"> 

<input name="name" type="text" id="name" size="15" value="<?php echo iconv("gb2312","utf-8",$rst->fields [1]):?>" /></td> 
<td align="center" bgcolor="#FFFFFF"> 

<input name="pass" type="password" id-"pass" value="<?php echo iconv("gb2312","utf-8", Srst->fields [2]):?>" size="15" /></td> 
<td align="center" bgcolor="#FFFFFF"> 

<input name="dates" type="text" id="dates" size="15" value="<?php echo iconv("gb2312","utf-8",S$rst->fields [3:?>" /></td> 
<td align="center" bgcolor="#FFFFFF"> 

<input type="hidden”" name="conn_id" value="<?php echo Srst- el ?>" 户 


<t> 
</form> 
<?php 
Srst->movenext (); 1 指针 下 移 
> 
Srst->close 0: /关闭 连接 


$conn->close (): 
Px 


(5) 创建 main okphp 文件 ， 完 成 管理 员 数 据 的 更 新 或 者 删除 操作 。 首 先 ， 初 始 化 SESSION 变量 ， 通 过 
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SESSION 变量 判断 当前 用 户 是 否 具 有 操作 权限 ， 如 果 有 权限 ， 则 可 以 根据 按钮 的 值 执行 更 新 或 者 删除 操作 ; 否 
则 将 给 出 提示 信息 ， 并 跳 转 到 管理 员 登 录 页 面 ， 其 代码 如 下 : 
<?php 


Session start(): 
header ( "Content-type: text/html: charset=utf-8" ); /设置 文件 编码 格式 
if($_SESSION['name']!=""){ 
include("conn/conn.php"); 
if($_POST['Submit21 一 "删除 "){ 
$sql="delete from tb_admin where id=".$_POST['conn id]"": 
Srst = $conn->execute ( $sql ) or die ( 'error: '. $conn->errorMsg (0 ); 
这 Srsb{ 
echo "<script>alert( 管 理 员 删除 成 功 ! ");window.location href="main.php';</script>"; 
Jelse{ 
echo "<script>alert( 管 理 员 删 除 失败 ! ');windwo.location.href='main.php'</script>"; 
} 


} 
if($_POST[Submit] 一 "更 新 "){ 
$sql="update tb_admin set 
name=".iconv("utf-8","gb2312",$ POST['name').",pass=".md5(iconv("utf-8","gb2312",$ POST['pass")).",dates=".$ POSTTdates1" where 
id=".$_POST['conn id].™; 
S$rst = $conn->execute ( $sql ) or die ( 'error: '. $conn->errorMsg 0 ); 
if(Srst){ 

echo "<script>alert( 管 理 员 更 新 成 功 ! ):window.location hre 人 main php';</script>"; 
Jelse{ 

echo "<script>alert( 管 理 员 更 新 失败 ! ，);windwo.location.href='main.php'</script>"; 
1 


} 

jelsef 

echo "<script>alert(' 您 不 具备 管理 员 权限 ! );windwoocation href-index.php'</script>": 
} 


> 


秘笈 心 法 

心 法 领悟 533: SESSION 变量 的 应 用 。 

通过 SESSION 变量 的 值 来 判断 当前 用 户 的 权限 是 非常 实用 的 方法 , 其 原理 是 : 在 会 员 或 者 管理 员 登 录 成 功 
后 , 将 登录 的 名 称 或 者 一 个 指定 的 值 赋 给 SESSION 变量 , 由 于 SESSION 变量 可 以 实现 在 不 同 页 面 之 间 的 传递 ， 
所 以 可 以 在 具有 访问 权限 限制 的 页 面 中 判断 这 个 SESSION 变量 的 值 ,如果 变 量 值 为 真 ， 则 说 明 这 个 用 户 具有 访 
问 权限 ， 否 则 说 明 当前 用 户 不 有 具备 访问 权限 。 


力 实例 说 明 


在 本 实例 中 ， 同 样 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 其 不 同 之 处 是 将 连接 、 操 作 数据 库 的 方法 封装 
到 类 中 ， 同 时 将 数据 库 中 数据 的 分 页 方法 也 封装 到 类 中 ， 还 有 通过 Smarty 模板 完成 页 面 的 动静 分 离 。 本 实例 完 
成 数据 库 中 员工 信息 的 分 页 输出 ， 其 运行 结果 如 图 12.16 所 示 。 


了 


护 8 


页 首页 上 -页 下 一 页 尾 页 


12.16 ”Smarty+Adodb 完成 Oracle 数据 的 分 页 显示 
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力 关键 技术 


本 实例 的 关键 是 应 用 面向 对 象 技术 ， 将 Oracle 数据 库 的 连接 、 操 作 以 及 分 页 方法 都 封装 到 类 中 ， 同 时 还 包 
括 Smarty 模板 的 配置 方法 。 应 用 类 的 实例 化 返回 的 对 象 调用 类 中 方法 ， 完 成 与 Oracle 数据 库 的 连接 、 操 作 和 分 


页 ， 最 终 通 过 Smarty 模板 完成 页 面 的 动静 分 离 。 


(1)Oracle 数据 库 连 接 类 ConnDB, 不 但 可 以 连接 Oracle 数据 库 , 还 可 以 连接 MySQL、 SQL Server 和 Access 


数据 库 。 该 类 存储 于 system system_.smarty.inc php 文件 中 ， 其 内 容 如 下 : 


class ConnDB{ 


function ConnDB(Sdbtype.Shost $user, Spwd,$dbname.Sdebug=false) { 
Sthis->dbtype=$dbtype; 


function GetConnIdO{ 
require("./adodbs/adodb.inc.php"); 
if(Sthis->dbtype—"oci8" | Sthis->dbtype 一 "mysql || Sthis->dbtype—"mssql"){ 
if(Sthis->dbtype—"mysql"){ 
Sthis->conn=NewADOConnection(“"mysql"); 
jelse if($this->dbtype—"mssql"){ 
Sthis->conn=NewADOConnection(“mssql"); 


Sthis->conn->Connect(S$this->host,$this->user, $this->pwd.,$this->dbname); 


jelsef 
Sthis->conn = ADONewConnection("oci8"); 
Sthis->conn->Connect($this->dbname. S$this->user, $this->pwd); 


} 
jelseifSthis->dbtype 一 "access"){ 
$this->conn=NewADOConnection("access"): 
S$this->conn->Connect("Driver={Microsoft Access Driver 
(*.mdb)}:Dbq=".$this->dbname.";Uid=".$this->user.":Pwd=" Sthis->pwd.";"); 
} 


Sthis->conn->Execute("set names utf8"): 
if($this->dbtype—"mysql") 

Sthis->conn->debug=$this->debug; 
Teturn $this->conn: 


} 
function CloseConnIdO{ 
Sthis->conn->DisconnectO: 
} 


/构造 方法 ， 为 成 员 变量 赋值 


/实现 与 不 同 数据 库 的 连接 并 返回 连接 对 象 
/调用 ADODB 类 库 文件 

1/ 判 断 成 员 变量 传递 的 数据 库 类 型 
1/ 判 断 如 果 是 MySQL 数据 库 

/执行 与 MySQI 数据 库 的 连接 

1/ 数据 库 连 接 的 用 户 、 密 码 


/建立 一 个 oracle 连接 


1/ 判断 如 果 使 用 的 是 Access 数据 库 


/执行 连接 Access 数据 库 
/设置 数据 库 的 编码 格式 


/返回 连接 对 象 


/定义 关闭 数据 库 的 方法 
1/ 执行 关闭 的 操作 


(2) 数据 库 操作 类 AdminDB， 执 行 对 Oracle 数据 库 的 操作 语句 ， 如 果 是 select 查询 语句 ， 成 功 则 返回 结 
果 集 数组 , 否则 返回 FALSE; 如 果 是 update、insert 或 者 delete 删除 语句 , 成 功 则 返回 TRUE, 否则 返回 FALSE。 


该 类 存储 于 system system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstr, $conn){ // 定 义 方法 ， 参 数 为 SQI 语句 和 连接 数据 库 返 回 的 对 象 
S$sqltype=strtolower(substr(trim(SsqlstD.0.6)): // 戴 取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 
Srs=$conn->Execute($sqlstr); /有 拱 行 SQL 语句 
if($sqltype—"select"){ /| 判断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRows(): /执行 该 语句 ， 获 取 查 询 结果 
这 count(Sarray) 一 0 | Srs 一 false) /l 济 断 语句 是 否 执行 成 功 
Tetum false; /如果 查询 结果 为 0， 或 者 执行 失败 ， 则 返回 false 
else 
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Tetum $array: /否则 返回 查询 结果 的 数组 
jelseif ($sqltype—"update" | $sqltype—"insert" | $sqltype—"delete"){ 
// 判 断 如 果 SQL 语句 类 型 不 为 select， 则 执行 如 下 操作 
if($rs) 
Tetum true; /执行 成 功 返 回 TRUE 


Tetum false; /| 是 否 返 回 FALSE 


} 
(3) 分 页 类 SepPage， 定 义 两 个 方法 ShowDate0 和 ShowPage0 完 成 数据 的 分 页 输出 。 该 类 存储 于 system\ 
system.smarty.inc.php 文件 中 ， 代 码 请 参考 本 书 光 盘 。 
(4) Smarty 模板 的 配置 类 SmartyProject， 完 成 Smarty 应 用 的 配置 操作 ， 指 定 模板 页 存储 位 置 ， 指 定编 译 
文件 存储 位 置 。 该 类 存储 于 system\ system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


require("../Smarty/Smarty.class.php"); /调用 Smarty 文件 
class SmartyProject extends Smarty{ /定义 类 ， 继 承 Smarty 父 类 
function SmartyProjectO{ /定义 方法 ， 配 置 Smarty 模板 


Sthis->template_dir =" /| 指定 模板 文件 存储 在 根 目 录 下 
i yd /| 指定 编译 文件 存储 位 置 


} 
} 


图 设计 过 程 


(1) 创建 system 文件 夹 。 首 先 ， 定 义 system.smarty.inc.php 文件 ， 封 装 Oracle 数据 库 的 连接 和 操作 方法 ， 
以 及 Smarty 的 配置 方法 。 然 后 ， 定 义 system.inc.php 文件 ， 对 数据 库 的 连接 和 操作 类 以 及 Smarty 配置 类 进行 实例 
化 ， 并 返回 连接 对 象 。 最 后 ， 创 建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 ndex.php 文件 。 首 先 ， 包 含 类 的 实例 化 文件 。 然后， 应 用 Smarty 生成 一 个 注册 函数 ， 实 现 对 数 
据 库 中 数据 的 编码 格式 转换 。 接 着 ， 调 用 分 页 类 中 的 方法 完成 数据 的 分 页 输出 ， 并 将 返回 的 结果 存储 到 模板 变 
量 中 。 最 后 ， 指 定 模板 页 ， 其 代码 如 下 : 


<?php 
require_once("system/system.inc.php"); // 包 含 配 置 文件 
function unHtml($params) { // 创 建 模板 函数 
extract($params): // 读 取 数 据 
$str=iconv("gb2312","utf-8", $text); 
Tetumn $str; // 返 回 截取 结果 
} 
$smarty->register_function("Util", "unHtml"): /注册 模板 函数 
Sarr=$seppage->ShowDate("select * from tb_user ".$conn,3,$_GET["page"]): // 调 用 分 页 类 ， 实 现 分 页 功能 
if(!$ar) 
ne 
jelsef 
Ssmarty->assign("isbbs","T"); 
$smarty->assign("showpage",$seppage->ShowPage(" 员 工 "." 名 ".""."a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("arr", Sarr): 


} 
$smarty->assign('title'"Smarty+Adodb 完成 ORACL 数据 库 中 数据 的 分 页 显示 '): 
Sn 


(3) 创建 index.html 模板 页 ， 应 用 section 语句 循环 输出 数据 库 中 的 数据 ， 并且 应 用 注册 模板 函数 对 数据 的 
编码 格式 进行 转换 ， 同 时 输出 模板 变量 中 存储 的 分 页 超 链接 ， 其 关键 代码 如 下 : 


{if Sisbbs—"T"} 
{section name=arrid loop=$arr} 
<t> 


<td align="center" bgcolor="#FFFFFF">{$anfamrid].0} </td> 

<td align="center" bgcolor="#FFFFFF">{Util text=$anfarrid].1}</td> 
<td align="center" bgcolor="#FFFFFF">{Util text=$arfarrid].2} </td> 
<td align="center" bgcolor="#FFFFFF">{Util text=$ar[arrid].3}</td> 
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<td align="center" bgcolor="#FFFFFF">{Util text=$arr[amrid].4}</td> 


{/section} 


力 秘笈 心 法 


心 法 领悟 534: ADODB 类 库 和 Smarty 模板 。 

有 关 ADODB 类 库 的 具体 应 用 将 在 第 13 章 中 进行 详细 讲解 ， 而 Smarty 模板 的 应 用 可 以 参考 本 书 第 14 章 。 
在 本 实例 中 , 封装 数据 库 连 接 、 操 作 类 、 分 页 类 和 Smarty 模板 的 配置 类 是 一 个 非常 不 错 的 方法 , 推荐 读者 使 用 ， 
并 且 可 以 对 它 进行 不 断 地 完善 。 例 如 ， 扩 展 其 支持 更 多 的 数据 库 、 更 改 分 页 类 的 方法 以 及 更 改 Smarty 模板 中 配 
置 文件 的 存储 路 径 等 。 


趣味 指数 : 会 视窗 穴 | 


图 实例 说 明 
在 本 实例 中 ,应 用 Oracle 数据 库 的 存储 过 程 技术 ,实现 对 员工 信息 表 中 数据 的 更 新 操作 ,其 运行 结果 如 图 12.17 


所 示 。 
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图 12.17 存储 过 程 更 新 员工 信息 


图 关键 技术 


存储 过 程 是 为 执行 一 定 的 任务 而 组 合 在 以 前 的 SQL 和 /或 PL/SQL 语句 集 , 通常 由 以 下 儿 部 分 组 成 : 声明 部 
分 、 执 行 部 分 和 异常 处 理 部 分 ， 其 中 执行 语句 是 必须 的 ， 而 其 他 两 部 分 则 是 可 选 的 。 

创建 存储 过 程 的 前 提 条 件 是 用 户 具 有 创建 过 程 的 权限 ， 这 个 权限 可 以 由 DBA 赋予 用 户 ， 其 语法 如 下 : 

GRANT CREATE ANY PROCEDURE TO UserName; 

取消 权限 的 语法 如 下 : 

REVOKE CREATE ANY PROCEDURE FROM UserName; 

Oracle 数据 库 中 创建 存储 过 程 的 语法 如 下 : 

CREATE[OR REPLACE] PROCEDURE procedure_ name( 

argument1[{inloutlin out}] type. 

argument2[{inloutlin out}] type. 


argument2[{inloutiin ouf}] type 
) 

{is|as} 

<!- 类 型 变量 的 说 明 -> 
BEGIN 

<!- 执 行 部 分 -> 
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[EXCEPTION] 

<!-- 可 选 的 异常 处 理 部 分 -> 

END[procedure_name]; 

参数 说 明 : 

replace: 关键 字 为 可 选 值 ， 多 数 情况 下 会 使 用 。 其 作用 为 创建 存储 过 程 时 ， 如 果 同 名 过 程 已 经 存在 ， 则 删 
除 同名 过 程 , 然后 进行 创建 操作 。 有 一 点 需要 注意 , 同一 用 户 下 的 过 程 是 唯一 标识 的 , 如 果 创建 时 不 使 用 replace 
关键 字 ， 当 出 现 同名 过 程 时 ， 会 给 出 ORA-00955 错误 ， 表 示 名 称 已 经 被 现 有 对 象 使 用 。 

procedure name: 创建 过 程 的 名 称 ， 它 在 数据 库 中 同一 用 户 下 是 唯一 标识 。 

argument: 过 程 的 参数 名 称 ， 为 可 选 参数 。 

加 、out、in out: 参数 的 模式 ， 默 认 的 模式 为 站。in 模式 为 输入 参数 模式 ， 具 备 只 读 属性 ， 不 可 以 在 执行 过 
程 中 赋值 ，out 模式 为 输出 参数 模式 ，in out 为 输入 /输出 参数 模式 。 

type: 指定 参数 的 数据 类 型 。 其 对 形 参 的 定义 只 可 以 指定 类 型 ， 不 可 以 限定 精度 。 

islas: 该 关键 字 到 BEGIN 关键 字 之 间 为 过 程 的 声明 部 分 。 声 明 包括 类 型 、 游 标 、 常 量 、 变 量 、 异 常 和 医 套 
子 程序 的 声明 ， 此 处 不 需 DECLARE 关键 字 ， 而 且 此 声明 部 分 中 声明 的 都 是 本 地 和 局 部 声明 ， 即 过 程 结 束 时 声 
明 终止。 

BEGIN 关键 字 和 END 关键 字 之 间 为 过 程 的 执行 部 分 ,如 果 过 程 中 存在 异常 处 理 , 则 BEGIN 和 EXCEPTION 
关键 字 之 问 为 过 程 的 执行 部 分 ，EXCEPTION 和 END 关键 字 之 间 为 异常 处 理 部 分 。 

在 本 实例 中 创建 的 存储 过 程 如 下 : 

CREATE OR REPLACE PROCEDURE PROC USER( 


Pp id IN integer, 
Pp_position IN VARCHAR 


update tb_user set position=p_position where id=p_id; 
commit 
END PROC USER; 


图 设计 过 程 

(1) 创建 conn 文件 ， 编 写 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 包 含 数 据 库 连接 文件 ， 应 用 Oracle 函数 读 取 Oracle 数据 库 中 的 数据 ， 并 通过 
while 语句 完成 数据 的 循环 输出 。 创 建 form 表单 ， 完 成 员工 更 新 信息 的 提交 ， 将 更 新 数据 提交 到 index_ok.php 
文件 中 ， 其 关键 代码 如 下 : 

<?php 

include("conn/conn.php"); 

$query="select * from tb_user "; 

Sresult=oci parse($conn,$query); 

Sr = oci_execute(Sresult OCI_DEFAULT): 
while(Srow=oci_fetch amray(SresultOCL RETURN_NULLS){ 


?> 
<form id="form<?php echo $row[0]:?>" name="form<?php echo Srow[0]:?>" method="post" action="update_ok.php"> 
<t> 


<td align="center" bgcolor="#FFFFFF"><?php echo $row[01:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[1]:?></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="position" type="text" value="<?php echo $row[21:?>" size="15" /> 
<input type="hidden" name="conn_id" value="<?php echo $row[0]:?>" /></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[3]:2></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[4]:?></td> 
<td align="center" bgcolor—"#FFFFFF"><input type="submit" name="Submit" value=" 更 新 " /></td> 


oci_close($conn): 
> 


(3) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 调 用 存储 过 程 完成 员工 信息 的 更 新 操作 ， 其 关键 代 
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码 如 下 : 
<?php 
header ( "Content-type: text/html: charset—utf-8" ): // 设 置 文 件 编码 格式 
include("conn/conn.php"); 
$sql = "BEGIN PROC_USER(:id, :position); END:": // 定 义 SQL 语句 
$stmt = OCIParse($conn, $sql); /执行 SQL 语句 
/执行 绑 定 
OCIBindByName($stmt, ":id", $ POST[conn id], 4); // 参 数 说 明 : 绑 定 php 变量 conn id 到 位 置 :id， 并 设 定 绑 定 长 度 为 4 位 
OCIBindByName($stmt, ":position", $ POST['position'], 50): 
if(OCIExecute($stmt){ // 调 用 并 执行 存储 过 程 
echo "<script>alert( 员 工 信 息 更 新 成 功 !):window.location href='index.php':</script>"; 
Jelse{ 

echo "<script>alert(' 员 工 信 息 更 新 失败 !);window.location href='index.php':</script>"; 

} 
> 

图 秘笈 心 法 


心 法 领悟 535: 在 PHP 动态 页 中 调用 存储 过 程 。 

在 PHP 动态 页 中 调用 存储 过 程 。 首先, 定义 SQL 语句 ,执行 存储 过 程 中 的 更 新 语句 。 然 后 ,通过 ociparseO 
函数 配置 Oracle 语句 预备 执行 。 接 着 ， 通 过 OCIBindByName0 函 数 绑 定 一 个 PHP 变量 到 一 个 Oracle 标识 符 。 
最 后 ， 通 过 OCIExecute0 函 数 执行 Oracle 语句 ， 完 成 员工 信息 的 更 新 操作 。 


12.4 _ Oracle 数据 的 导入 和 导出 


本 节 将 介绍 Oracle 数据 库 中 数据 的 导入 、 导 出 方法 。 


gy } CE 习 
| 实例 说 明 ETT TE TT = 3 
Wiml Dcw 了 BEal 

本 实例 将 Oracle 数据 库 中 的 数据 表 导 出 到 本 地 磁盘 C 下 的 mrsoft 文 IN 了 


件 夹 中 ， 并 将 导出 的 文本 文件 命名 为 oracle.dmp。 导 出 的 结果 如 图 12.18 区 


pa 诺 型 TFT 文件 修改 日 期 : 2.00 1D 
所 示 。 


关键 技术 图 12.18 导出 的 文本 文件 


本 实例 应 用 Oracle 数据 库 中 数据 库 逻 辑 备 份 工具 Export。 利用 Export 工具 可 以 在 数据 库 打开 状态 下 备份 数 
据 库 。Export 把 数据 库 中 的 对 象 导出 到 一 个 二 进 制 文件 中 。 该 工具 也 是 数据 库 间 进行 迁移 的 一 个 工具 。 

Export 有 3 种 方法 : 行 命令 法 、 交 互 式 方法 和 参数 文件 方法 。 下 面 主要 介绍 本 实例 中 使 用 的 参数 文件 方法 。 

将 EXP 命令 的 各 个 参数 放 在 一 个 参数 文件 中 ， 参 数 文件 的 命令 格式 如 下 : 

EXP [用 户 名 | 口令 ]PARFILE = 参数 文件 路 径 及 名 称 


以 下 是 一 个 参数 文件 的 示例 ， 代 码 如 下 : 
FULL 


[EE] 


INDEXES=Y 

其 中 ，FULL 设置 为 Y 时 ,会 导出 除 SYS 方案 对 象 外 的 所 有 的 方案 对 象 ， 如 果 设 置 为 FULL， 要 求 用 户 有 
EXP_ FULL DATABASE 权限 。 

FILE 参数 用 来 设置 导出 文件 的 目录 和 文件 名 。 
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来 设置 是 否 导出 权限 信息 。 
INDEXES 参数 默认 值 为 Y， 用 来 设置 是 否 导 出 表 和 聚集 的 索引 。 

图 设计 过 程 
(1) 选择 “开始 ”/“ 程 序 ”/“ 附 件 ”/“ 命 令 提示 符 ” 命 令 ， 进 入 DOS 命令 环境 。 
(2) 在 DOS 提示 符 下 输入 “EXP 用 户 名 | 口令 命令 ” (EXP 不 区 分 大 小 写 ) ， 进 入 导出 界面 ， 代 码 如 下 : 
exp system/mrsoft tables=(tb_user,tb_admin) file=C:\mrsoft\oracle.dmp 
(3) 按 Enter 键 ， 执 行 本 实例 ， 其 运行 结果 如 图 12.19 所 示 。 

TEE 


HS16GBK 


图 12.19 Oracle 数据 库 中 数据 表 的 导出 
力 秘笈 心 法 
心 法 领悟 536: Export 工具 导出 表 空 间 和 导出 数据 库 。 
通过 Export 工具 不 但 可 以 导出 表 ， 还 可 以 导出 表 空 间 、 分 区 和 数据 库 。 
(1) 导出 表 空 间 的 语法 如 下 : 
exp /demo/demo tablespaces=data 
(2) 导出 数据 库 ， 将 导出 所 有 的 数据 库 对 象 及 其 数据 ， 并 存储 到 指定 的 文件 系统 中 。 
@ 完全 导出 。 将 所 有 的 数据 库 对 象 及 数据 导出 到 文件 中 ， 并 为 积累 导出 和 增 量 导出 的 基点 安排 一 个 较 长 的 
周期 进行 完全 导出 ， 其 命令 如 下 : 
exp system/manager full=y inctype=complete file=export.dmp 
@) 增 量 导出 。 将 上 次 导出 以 来 已 经 发 生变 化 的 对 象 结构 及 数据 导出 到 文件 中 ， 其 命令 如 下 : 
exp system/manager full=y inctype=incremental file=export.dmp 


@ 积累 导出 .将 上 次 进行 积累 或 完全 导出 以 来 已 经 发 生变 更 的 对 象 及 其 数据 库 导出 到 文件 中 , 其 命令 如 下 : 
exp system/manager full=y inctype=cumulative file=export.dmp 


件 中 数据 导入 到 Oracle 高 级 
MR\12\537 趣味 指数 ， 博 请 请 家 


实例 537 


图 实例 说 明 
在 本 实例 中 ， 讲 解 将 文本 文件 中 数据 导入 到 Oracle 数据 库 中 。 数据 的 导入 应 用 的 是 import 工具 ， 同 样 也 分 为 
导入 表 、 导 入 方案 和 导入 数据 库 3 种 。 在 本 实例 中 将 文本 文件 oracle.dmp 中 存储 的 数据 导入 到 Oracle 数据 库 中 。 


说 明 : 在 执行 将 文本 文件 中 数据 导入 到 Oracle 数据 库 时 ， 必 须 确保 在 Oracle 数据 库 中 不 存在 与 文本 文件 中 
同名 的 数据 表 ， 否 则 导入 操作 不 会 成 功 。 
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13.1 封装 ADODB 操作 类 


ADODB 是 Active Data Objects Data Base 的 简称 ， 是 一 种 PHP 存 取 数 据 库 的 中 间 函 式 组 件 。 本 节 将 介绍 如 
何 对 ADODB 操作 数据 库 的 方法 进行 封装 ， 从 而 使 通过 ADODB 操作 数据 库 的 方法 更 加 简单 。 


加 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 adodb 类 库 文 件 ， 需 要 读者 自行 下 载 ， 
并 复制 到 本 章 的 13 文件 夹 下 ， 将 其 命名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


和 


实例 538 


图 实例 说 明 


连接 数据 库 类 的 封装 ， 意 味 着 通过 ADODB 连接 不 同 的 数据 库 的 方法 更 加 简单 、 更 容易 更 新 和 修改 。 只 要 
向 类 中 传递 对 应 的 参数 值 ， 即 可 完成 与 不 同 数据 库 服务 器 的 连接 。 在 本 实例 中 ， 以 MySQL 数据 库 服 务 器 为 例 ， 
实现 与 db_database13 数据 库 的 连接 ， 连 接 成 功 后 弹出 提示 信息 ， 其 运行 结果 如 图 13.1 所 示 。 


[hE 


mrbecarcomen 


图 13.1 ADODB 连接 数据 库 类 


ADODB 连接 数据 库 系 统 使 用 ADONewConnection0 函 数 ， 如 果 选 择 持久 化 连接 则 使 用 PConnect0 函 数 ， 如 
果 选 择 非 持 久 化 连接 则 使 用 ConnectO 函 数 。 
CL es 连接 数据 库 系统 ， 其 语法 如 下 : 


Pi 

参数 $databaseType 家 下 连接 的 数据 库 系统 的 名 称 ， 例如 mysql、mssql 等 。 
(2) PConnectO 函 数 ， 实 现 与 数据 库 的 持久 化 连接 ， 其 语法 如 下 : 
PConnect($host[$user],[$password].[$database]) 
参数 说 明 : 
$host: 数据 库 系 统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 
$password: 数据 库 密码 。 
$database: 使 用 到 的 数据 库 。 

(3) Connect0 函 数 ， 实 现 与 数据 库 的 非 持久 化 连接 ， 其 语法 如 下 : 
Connect($host.[Suser].[Spassword].[$database]) 
参数 说 明 : 
$host: 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 
$password: 数据 库 密码 。 
$database: 使 用 到 的 数据 库 。 
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掌握 连接 数据 库 服务 器 所 使 用 的 函数 之 后 ， 就 是 定义 类 、 方 法 和 参数 ， 完 成 与 指定 数据 库 服 务 器 的 连接 ， 
并 返回 连接 标识 ， 其 具体 代码 将 在 设计 过 程 中 进行 介绍 。 
图 设计 过 程 
(1) 创建 found.database.php 文件 ， 定 义 ConnDB 连接 数据 库 类 ， 定 义 ConnDB0 方 法 为 成 员 变量 赋值 ， 定 


义 GetConnId0 方 法 实现 与 不 同 数据 库 服务 器 的 连接 :并 返回 连接 标识 ; 最 后 定义 CloseConnId0 方 法 关闭 数据 库 
连接 ， 其 关键 代码 如 下 : 


Sthis->conn=NewADOConnection("mysql"); 


else 


$this->conn=NewADOConnection("mssql" 


<?php 
/ 渍 据 库 连 接 类 
class ConnDB{ 
var $dbtype; /项 据 库 服 务 器 类 型 
var $host // 服 务 器 名 称 
Var $user; 1 用 户 名 
var $pwd; /密码 
var $dbname; /数据 库 名 称 
var $debug; // 是 否 返 回执 行 的 SQL 语句 ， 默 认 设置 为 返回 SQL 
var $conn; // 连 接 数 据 库 时 返回 的 连接 标识 
function ConnDB($dbtype, $host, $user, S$pwd.$dbname,$debug=true){ /构造 方法 ， 为 成 员 变 量 赋 值 
Sthis->dbtype=$dbtype; 
Sthis->host=$host; 
Sthis->user=S$user; 
S$this->pwd=$pwd; 
Sthis->dbname=$dbname; 
1 Sthis->debug=$debug; 
function GetConnIdO{ 1/ 实现 与 不 同 数据 库 的 连接 并 返回 连接 对 象 
Tequire("../adodb5/adodb.inc.php"); /1/ 调 用 ADODB 类 库 文件 
if($this->dbtype—"mysql" | $this->dbtype—"mssql"){ /1/ 判 断 成 员 变 量 传递 的 数据 库 类 型 
if($this->dbtype—"mysql") 1/ 判断 如 果 是 MySQL 数据 库 


/执行 与 MySQI! 数据 库 的 连接 


Sthis->conn->Connect(Sthis->host, S$this->user, Sthis->pwd.Sthis->dbname); 1/ 数据 库 连 接 的 用 户 、 密 码 


Jelseif($this->dbtype—"access"){ 
Sthis->conn=NewADOConnection("access"):; 


1/ 判断 如 果 使 用 的 是 Access 数据 库 


Sthis->conn->Connect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=".$this->dbname.";Uid=".$this->user."; 


Pwd=".$this->pwd.";"); /执行 连接 Access 数据 库 
} 
Sthis->conn->Execute("set names utf8"); /设置 数据 库 的 编码 格式 
if($this->dbtype—"mysql") 
Sthis->conn->debug=$this->debug:; 
Teturn S$this->conn: /返回 连接 对 象 
} 
fnction CloseConnIdO{ // 定 义 关闭 数据 库 的 方法 
Sthis->conn->DisconnectO; /执行 关闭 的 操作 


} 
} 
> 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB， 并 向 类 中 传递 对 应 的 参数 ， 完 成 与 


MySQL 数据 库 服务 器 中 db _database13 数据 库 的 连接 ， 其 关键 代码 如 下 : 
<2php 


require("found.database.php"): /包含 类 文件 
S$connobj=new ConnDB("mysql"."localhost"."root""111"."db_database13".false): /数据 库 连接 类 实例 化 
Sn /返回 连接 标识 


3 创建 index.php 文件 ， 包 含 数据 库 连接 类 的 实例 化 文件 ， 根 据 返 回 的 连接 标识 判断 数据 库 是 否 连接 成 


功 ， 其 关键 代码 如 下 : 
<2php 
include_once ‘conn/connect.database.php'; 
if($conn){ 
echo "<script>alert( 数 据 库 连 接 成 功 ! ):window-.location href-http://www.mrbccd.com':</script>": 


// 包 含 数据 库 连 接 类 的 实例 化 文件 
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jelsef 
echo "<script>alert( 数 据 库 连接 失败 ! :window .location href=index php':</script>"; 
} 


> 


力 秘笈 心 法 


心 法 领悟 538: 通过 ADODB 连接 数据 库 服务 器 必须 注意 的 问题 。 

定义 连接 数据 库 类 ， 再 定义 连接 方法 GetConnId0 时 ， 必 须 先 通过 require0 语 句 包含 ADODB 类 库 文件 
adodb.inc.php， 和 否则 其 他 一 切 操作 都 无 从 谈 起 。 

建议 在 程序 的 开发 阶段 运用 连接 数据 库 操作 类 时 ， 将 参数 $debug 的 值 设 置 为 TRUE， 这样 可 以 返回 执行 的 
SQL 语句 ,便于 获取 SQL 语句 在 执行 过 程 中 出 现 的 错误 。 如 果 是 在 生产 环境 中 运用 连接 数据 库 类 ， 那么 就 要 将 
$debug 的 值 设置 为 FALSE。 


实例 539 


图 实例 说 明 

既然 可 以 将 ADODB 连接 数据 库 的 方法 封装 到 类 中 ， 那 么 同样 也 可 以 将 ADODB 操作 数据 库 的 方法 封装 到 
类 中 。 在 本 实例 中 ， 介 绍 如 何 将 ADODB 操作 数据 库 的 方法 封装 到 类 中 ， 并 且 通 过 该 方法 读 取 MySQL 数据 库 
服务 器 的 db_database13 数据 库 中 的 tb_bccd 数据 表 中 的 数据 ， 其 运行 结果 如 图 13.2 所 示 。 
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图 13.2 ADODB 操作 数据 库 类 


ADODB 操作 数据 库 类 为 AdminDB， 在 操作 数据 库 的 ExecSQL0 方 法 中 ， 关 键 是 以 下 儿 个 函数 的 运用 : 
(1) strtolower0 函 数 ， 将 字符 串 转换 为 小 写字 母 ， 其 语法 如 下 : 

string strtolower(string str) 

运用 本 函数 的 目的 是 将 SQL 语句 中 的 字符 串 都 转换 为 小 写 。 

(2) substr0 函 数 ， 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 ， 其 语法 如 下 : 

string substr(string strint start.int length) 

参数 说 明 : 

str: 指定 截取 的 字符 串 。 

start: 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末尾 开始 截取 。 

length: 可 选 参数 ， 指 定 截取 字符 串 的 长 度 。 如 果 为 负数 ， 则 表示 取 倒 数 第 length 个 字符 。 


< 注意 : 本 函数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 一 个 字符 表示 为 0。 


运用 substr0 函 数 对 SQL 语句 中 前 6 个 字符 串 进 行 截取 ， 其 目的 是 获取 SQL 语句 的 类 型 (insert、select 或 
者 update) ， 判 断 其 执行 的 是 什么 操作 。 
(3) trim0 函 数 ， 删 除 字符 串 中 首尾 的 空白 或 者 其 他 字符 。 
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(4) execute0 函 数 ，ADODB 中 执行 SQL 语句 的 方法 ， 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 失 败 
则 返回 FALSE， 其 语法 如 下 : 

execute(Ssql[.Sinputarr=false]) 

参数 说 明 : 

$sql: 指定 要 执行 的 SQL 语句 。 

$inputarr: 设置 传 入 的 结合 变量 ， 如 果 没 有 设置 $inputarr， 则 $sql 为 普通 的 SQL 语句 ， 函 数 execute0 的 格式 
如 下 : 


Sconnect->execute('select * from tb_user where id =1) 

如 果 设 置 了 $inputarr， 函 数 execute0 的 格式 如 下 : 

Sconnect -> execute('select + from tb_user where id = ?array(SvD) 

(5) GetRows0 函 数 ， 是 GetArray0 的 同 义 函数 ， 是 为 了 与 Microsoft ADO 相 容 定义 的 ， 其 语法 如 下 : 
GetRows ([$number of rows]) 

返回 从 当前 指针 指向 的 记录 开始 ， 到 ($number_of rows - 1) 行 的 全 部 记录 的 数组 。 参 数 $number_of rows 


表示 指定 的 记录 行 ， 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停 止 。 
图 设计 过 程 


(1) 创建 found.database.php 文件 ， 定 义 数 据 库 操作 类 AdminDB， 定 义 ExecSQL0 方 法 ， 根 据 传递 的 SQL 
语句 执行 对 数据 库 的 操作 。 在 ExecSQL 方法 中 ， 应 用 substrO 函 数 获 取 参 数 传递 的 SQL 语句 的 类 型 ， 然 后 根据 
SQL 语句 的 类 型 进行 判断 , 如 果 是 select 查询 语句 , 则 执行 GetRow0 方 法 , 获取 查询 结果 ; 如 果 是 update、 insert 
或 者 delete 语句 ， 则 直接 返回 TRUE 或 者 FALSE， 其 代码 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstr, $conn) { /定义 方法 ， 参 数 为 SQL 语句 和 连接 数据 库 返 回 的 对 象 
Ssqltype=strtolower(substr(trim($sqlstr).0.6)); /截取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 
Srs=$conn->Execute($sqlstr); /| 执行 SQL 语句 
if($sqltype—"select"){ 1/ 判断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRowsO; /| 执行 该 语句 ， 获 取 查 询 结果 
if(count(Saray}=—0 || Srs—false) // 判 断 语句 是 否 执 行 成 功 
Tetum false; // 和 如果 查 询 结 果 为 0， 或 者 执行 失败 ， 则 返回 FALSE 
else 
Tetum Sarray; /否则 返回 查询 结果 的 数组 


Yelseif ($sqltype—"update" || $sqltype 一 "insert" || $sqltype—"delete"){ 
/判断 如 果 SQL 语句 类 型 不 为 select、 则 执行 如 下 操作 


这 Srs) 

Teturn true; /| 执行 成 功 返回 TRUE 
else 

Tetumn false; /否则 返回 FALSE 


上 
} 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连接 类 ConnDB 和 数据 库 操作 类 AdminDB， 其 关键 代 


码 如 下 : 
<?php 
require("found.database.php"); // 包 含 类 文件 
Sconnobj=new ConnDB("“mysql","localhost","root","111","db_database13",false); /实例 化 数据 库 连接 类 
$conn=S$connobj->GetConnlIdO: /返回 连接 标识 
S$admindb=new AdminDBO: // 实 例 化 数据 库 操作 类 


2 
(3) 创建 ndex.php 文件 ， 包 含 数据 库 连 接 类 和 数据 库 操作 类 的 实例 化 文件 ， 定 义 SQL 语句 ， 调 用 数据 库 
操作 类 中 的 ExecSQL0 方 法 执行 SQL 查询 语句 , 最 后 通过 for 语句 循环 输出 ExecSQLO 方 法 返回 的 查询 结果 , 其 
大 


ee once ‘conn/connect.database.php': // 包 含 数据 库 连 接 类 和 操作 类 的 实例 化 文件 
$sqlstr = 'select * from tb_bccd’; // 定 义 SQL 语句 

Sarray = $admindb->ExecSQL(S$sqlstr.$Sconn): // 调 用 数据 库 操作 类 中 的 方法 ， 执 行 查询 操作 
for($i=0:$i<count($Sarray): Sit+){ /通过 for 循环 输出 数据 库 中 的 数据 
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> 
<t> 
<td align="center" bgcolor="#FFFFFF"><?php echo Sarray[$il[01:?></td> 
<td align="center”" bgcolor="#FFFFFF"><?php echo Sarray[$i][1]:?></td> 
<td height="22" align="center" bgcolor="#FFFFFF"><?php echo $array[$i][2]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo Sarray[$il[31:7></td> 
<> 
i 3 
> 


图 秘笈 心 法 


心 法 领悟 539: 判断 SQL 语句 类 型 的 技巧 。 

SQL 语句 的 类 型 分 为 查询 (select) 、 添 加 (insert) 、 更 新 update) 和 删除 (delete) 4 种 。 这 4 个 英文 单 
词 有 一 个 共同 的 特点 ， 即 都 是 由 6 个 英文 字母 组 成 。 我 们 就 是 根据 这 个 共同 点 对 SQL 语句 的 类 型 进行 判断 的 。 
这 也 就 是 在 实例 中 应 用 substr0 函 数 对 SQL 语句 的 前 6 个 字符 串 进行 截取 的 原因 。 


实例 540 


国 实例 说 明 


为 了 更 方便 地 通过 ADODB 操作 数据 库 中 的 数据 ， 这 里 对 ADODB 类 库 中 提供 的 分 页 函数 进行 整合 ， 封 装 
为 一 个 ADODB 分 页 类 ， 并 且 运 用 ADODB 分 页 类 输出 MySQL 数据 库 db_database13 中 tb_user 数据 表 中 的 数 
据 ， 其 运行 结果 如 图 13.3 所 示 。 


Mw x 


“一 、 
4 三 


避 8 俩 允 歧 


明日 科技 


共有 用 户 83 个 多 页 显示 10 个 第 2 页 共 $ 页 首页 上 一 页 下 一 页 尾 页 


图 13.3 ADODB 分 页 类 的 应 用 


力 关键 技术 


在 ADODB 分 页 类 SepPage0 中 ， 主 要 整合 下 面 几 个 ADODB 中 的 函数 : 
(1) PageExecute0 函 数 ， 分 页 功能 函数 ， 其 语法 如 下 : 
PageExecute($sql, $nrows, Spage); 

参数 说 明 : 

$sql: SQL 查询 语句 。 

$nrows: 每 页 显示 的 记录 数 。 

$page: 保存 当前 页 数 ， 默 认为 1。 

(2) AbsolutePage0 函 数 ， 返 回 当前 页 的 页 数 ， 其 语法 如 下 : 
AbsolutePage(Spage—1) 

该 函数 要 与 PageExecute0 函 数 配 合 使 用 。 


(3) AtFirstPageO0 函 数 ， 如 果 当 前 页 是 第 一 页 ， 则 返回 TRUE， 其 语法 如 下 : 
5 


irstPage(Sstatus—") 
要 与 PageExecute0 函 数 配合 使 用 ， 判 断 当 前 是 否 是 第 一 页 。 
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(4) AtLastPage0 函 数 ， 判 断 当前 页 是 否 是 最 后 一 页 ， 其 语法 如 下 : 
AtLastPage($status="); 
同样 要 与 PageExecute0 函 数 配 合 使 用 ， 判 断 当 前 页 是 否 是 最 后 一 页 ， 如 果 是 则 返回 TRUE。 
本 实例 中 就 是 整合 了 上 述 几 个 ADODB 类 库 中 的 函数 ， 封 装 了 一 个 ADODB 分 页 类 。 


图 设计 过 程 
(1) 创建 found.database.php 文件， 定义 SepPage 分 页 类 ， 定 义 ShowData() 方 法 ， 读 取 数 据 库 中 存储 的 数 


据 ， 并 且 将 查询 结果 返回 到 数组 中 。 定 义 ShowPage0 方 法 ， 创 建 分 页 超 链接 ， 完 成 从 数据 库 中 读 取 数据 的 分 页 
输出 。SepPage 分 页 类 的 关键 代码 如 下 : 


class SepPage{ 
Var $rs; 
Var $pagesize: 
Var $nowpage; 
Var $array; 
Var Sconn; 
Var $sqlstr; 
function ShowData($sqlstr, $conn. $pagesize. Snowpage){ // 定 义 方法 
if(!isset($nowpage) || Snowpage—"") / 济 断 变量 值 是 否 为 空 
S$this->nowpage=1; // 定 义 每 页 起 始 页 
else 
Sthis->nowpage=$nowpage; 
Sthis->pagesize=$pagesize; /定义 每 页 输出 的 记录 数 
Sthis->conn=$conn; /连接 数据 库 返回 的 标识 
Sthis->sqlstr=$sqlstr; // 执 行 的 查询 语句 
Sthis->rs=$this->conn->PageExecute($this->sqlstr.$this->pagesize.$this->nowpage): 
@$this->array=$this->rs->GetRows(); /| 获取 记录 数 
这 count($this->array) 一 0 || $this->rs—false) 
Tetum false; 
else 
Tetum S$this->array; 
/省 略 了 ShowPage0 方 法 中 的 内 容 


} 
(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连接 类 ConnDB、 数 据 库 操作 类 AdminDB 和 分 页 类 
SepPage， 其 关键 代码 如 下 : 


<?php 

Tequire("found.database.php"): // 包 含 类 文件 
S$connobj=new ConnDB("mysql"."localhost","root","111","db_database13",false); /实例 化 数据 库 连 接 类 
S$conn=$connobj->GetConnId0; 

Sadmindb=new AdminDBO; // 实 例 化 数据 库 操作 类 
$seppage=new SepPage(): // 实 例 化 分 页 类 

?> 


(3) 创建 index.php 文件 ， 包 含 connect.database.php 文件 ， 调 用 分 页 类 中 的 ShowData() 方 法 ， 完 成 数据 的 
分 页 输出 ， 调 用 分 页 类 中 的 ShowPage0 方 法 输出 分 页 的 超 链 接 ， 其 关键 代码 如 下 : 


<?php 

include_once 'conn/connect.database .php': // 调 用 类 中 方法 
$array=$seppage->ShowData("select + from tb_user".$conn.10.$S_GET["page"]): // 分 页 读 取 数据 库 中 数据 
for($i=0;$i<count($array):Sit+){ /循环 输出 数据 库 中 数据 
> 

<tr> 


<td height="20" align="center" bgcolor="#FFFFFF"><?php echo $array[$i][0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][1]:2></td> 
<td align="center”" bgcolor="#FFFFFF"><?php echo $array[$il[21:?></td> 


<td height="35" ><?php echo $seppage->ShowPage(" 用 户 "." 个 "." 参 数 1"." 参 数 2"."a1"):?></td> 
<> 
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力 秘笈 心 法 

心 法 领悟 540: ADODB 分 页 类 的 运用 技巧 。 

在 运用 ADODB 分 页 类 进行 数据 的 分 页 输出 时 ， 向 ShowData0 方 法 中 传递 4 个 参数 ，SQL 查询 语句 、 数 据 
库 的 连接 标识 、 每 页 显示 的 记录 数 和 当前 页 码 ; 向 ShowPage( 方 法 中 传递 5 个 参数 : 数据 的 类 型 、 数 据 的 单位 、 
超 链接 的 参数 一 、 参 数 二 和 超 链接 样式 。 


13.2 ADODB 的 应 用 
ADODB 类 库 非常 庞大 ， 仅 一 个 adodb.inc.php 文件 就 有 120KB。 本 节 将 详细 讲解 ADODB 类 库 中 的 连接 数 


据 库 函 数 、 操 作 数据 库 函 数 、 公 用 变量 、 公 用 函数 、 结 果 集 处 理 函数 和 错误 处 理 函数 等 在 实例 中 的 具体 应 用 。 


实例 541 


趣味 指数 : 伍 食 伍 侧 


图 实例 说 明 


在 实例 540 中 介绍 了 如 何 将 ADODB 中 的 分 页 函数 封装 到 类 中 ， 并 通过 分 页 类 完成 数据 的 循环 输出 操作 。 
而 在 本 实例 中 ， 则 还 原 分 页 函数 的 本 来 面貌 ， 通 过 面向 过 程 的 方法 编写 一 个 数据 分 页 输出 的 实例 ， 了 解 分 页 函 
数 的 具体 应 用 。 本 实例 的 运行 结果 如 图 13.4 所 示 。 


| 
| 
| 
图 13.4 ADODB 分 页 函数 的 应 用 
图 关键 技术 
有 关 ADODB 类 库 中 分 页 函数 的 详细 介绍 可 以 参考 实例 540 关键 技术 中 的 内 容 ， 这 里 不 再 歼 述 。 在 本 实例 


引入 rs2html0 函 数 ， 直 接 将 PageExecute0 函 数 返回 的 查询 结果 以 表格 的 形式 输出 。 


Is2html0 函 数 ， 返 回 一 个 HTML 表格 格式 的 结果 集 ， 其 语法 如 下 : 
1s2htmi($rst,[Stable_ attributes]. [Scol_ titles]) 


参数 说 明 : 

$rst: 要 返回 的 结果 集 。 

table_attributes: 对 表格 的 参数 及 属性 的 设置 。 
col title: 对 字段 的 重新 命名 。 


Ah 注意 : 运用 rs2html0 函 数 的 前 提 是 ， 必 须 载 入 tohtmLiniphp 文件 。 
图 设计 过 程 


(1) 创建 com 文件 来， 编写 conn php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服 务 器 中 
db _databasel13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 utf8， 其 代码 如 下 : 


中 
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<?php 

include_once (Jadodbs/adodb inc phpy: 

Sconn = ADONewConnection(mysql); 

$conn -> PConnect(localhost',root'"111',db_database13); 
Sconn -> execute('set names utf8); 


> 


/ 厂 入 (include) adodb.inc.php 文件 
/建立 连接 

// 连 接 数 据 库 

// 设 置 编码 格式 


(2) 编程 index php 文件 。 首 先 ， 包 含 数据 库 连接 文件 conn.php， 然 后 载 入 tohtmlini php 文件 ， 最 后 ， 定 
义 SQL， 应 用 ADODB 类 库 中 的 分 页 函数 完成 数据 的 分 页 输出 ， 并 且 应 用 rs2html0 函 数 直 接 将 分 页 查询 的 数据 


定义 到 表格 中 ， 其 关键 代码 如 下 : 
<?php 


include_once 'conn/conn.php'; 
include ('../adodbs/tohtml inc.php); 
$sql = 'select + from tb_bced'; 
Snum = 3; 

if(isset ($_GET [n_page] )) { 


} 
Srst = $conn->PageExecute ( $sql, $num, $c_page ); 
if (false (= $rst) { 
?> 
<t> 
<td><?php 


Ts2html ( $rst, ‘width="775" border="1" align=" 


bgcolor="#999999", array (ID', ' 名 称 ', 类 型 ' 添加 时 间 ' ) ): 
2></td> 


/| 省 略 了 部 分 代码 
<Iphp 


> 


秘笈 心 法 


心 法 领悟 541: 将 分 页 读 取 的 数据 存储 到 缓存 中 。 


/人 入 数据 库 连 接 文件 

/ 厂 入 tohtmlinc php 文件 
/查询 语句 
/每 页 显示 的 记录 数 

/1/ 判 断 当前 页 码 

// 将 $n_page 赋 给 变量 Sc_apge 


/初始 化 变量 Sc_page 
/执行 PageExecute0 函 数 


"center" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" 


了 PageExecute0 函数 可 以 执行 分 页 功能 ， 但 是 如 果 要 将 分 页 查询 的 结果 存储 到 缓存 中 ， 就 必须 使 用 
CachePageExecute($sec, $sql, $nrows, $page) 函 数 ， 其 不 但 具备 PageExecute0 函 数 的 功能 , 而 且 可 以 将 显示 后 的 记 
录放 到 缓 在 中 。 在 $sec 秒 内 ， 如 果 需 要 重复 查看 ， 将 从 缓存 中 读 取 数 据 。 


实例 542 


力 实例 说 明 


分 页 功能 高 级 


趣味 指数 : 帘 食 俩 而 | 


在 ADODB 类 库 中 ， 不 只 提供 了 分 页 函数 ， 还 提供 了 封装 好 的 分 页 类 供 开发 者 使 用 。 在 本 实例 中 ， 运 用 
ADODB 类 库 中 提供 的 ADODB pager 类 实现 分 页 功能 ， 分 页 输出 编程 词典 的 注册 用 户 ， 其 运行 结果 如 图 13.5 


所 示 。 


首页 上 一 页 下 一 页 尾 册 


图 13.5 ADODB pager 分 页 类 
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图 关键 技术 


ADODB_Pager0 函 数 ， 是 ADODB Pager 类 的 构造 函数 ， 通 过 类 中 的 renderO 函 数 可 以 实现 分 页 功能 ， 其 语 
法 如 下 : 

ADODB_Pager(Sconn, $sql. $id ='adodb' $showPageLinks = false) 

参数 $conn 是 数据 库 连 接 对 象 ， 参数 $sql 是 执行 的 SQL 语句 ;参数 $id 为 每 个 分 页 的 id 号 ; 参数 
$showPageLinks 设置 是 否 显示 各 个 页 的 链接 ， 默 认为 FALSE。 


闪 提示 : 应 用 ADODB_ pager(O 函 数 实现 分 页 功能 的 前 提 和 条件， 必须 载 入 adodb-pageriniphp 文件 。 
图 设计 过 程 


(1) 创建 conn 文件 来， 编写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_databasel13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 utf-8， 其 代码 如 下 : 


<?php 

include_once ('./adodbs/adodb inc php) / 厂 入 (include) adodb inc php 文件 
$conn = ADONewConnection(mysql); // 建 立 连接 

$conn -> PConnect('localhost''root,'111''db_database13"); /连接 数据 库 

Sconn -> execute('set names utf8"); /设置 编码 格式 


> 
(2) 创建 index.php 文件 , 完成 数据 的 分 页 输出 。 首先 , 包含 数据 库 连 接 文件 。 然后, 载 入 adodb-pager.ini.php 
文件 。 最 后 ， 实 例 化 ADODB_Pager 类， 调用 Render0 方 法 ， 设 置 每 页 显示 10 条 记录 ， 其 关键 代码 如 下 : 
<2php 


include ‘conn/conn.php’; /三 入 数据 库 链接 文件 
include_once ' adodb-pager.inc.php'; / 伐 入 adodb_parper.ini.php 文件 
人 声明 对 象 对 


Spager = new ADODB_Pager($conn,"select id,user as 用户 名 ', pass as 密码 ',dates as ' 注 册 时 间 ' from tb_user"); 
作 ”调用 $Render 函数 确定 每 页 显示 多 少 记录 */ 

Spager -> Render(10); 

> 


图 秘笈 心 法 


心 法 领悟 542: 修改 ADODB_Pager 类 中 定义 的 分 页 方法 的 样式 。 

修改 ADODB _Pager 类 中 定义 的 分 页 方法 的 样式 ， 即 对 载 入 的 adodb-pager.ini.php 文件 进行 修改 。 可 以 修 
改 的 内 容 包括 超 链 接 、 表 格 背 景 、 宽 度 、 边 框 宽度 和 颜色 等 。 在 本 实例 中 ， 将 超 链接 修改 为 中 文 ， 并 且 重 新 
定义 了 表格 的 宽度 。 为 了 便于 读者 使 用 , 还 将 修改 后 的 adodb-pager.ini.php 从 ADODB 类 库 中 复制 到 实例 的 根 
目录 下 。 


实例 543 


图 实例 说 明 

通过 ADODB 类 库 操 作 数 据 库 ， 不 但 要 掌握 数据 库 的 连接 方法 ， 还 要 掌握 操作 结果 集 的 方法 。 在 本 实例 中 ， 
将 介绍 ADODB 类 库 中 操作 结果 集 的 方法 ， 并 且 应 用 其 中 的 方法 循环 输出 数据 表 中 的 字段 和 值 ， 其 运行 结果 如 
图 13.6 所 示 。 
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| 达 3 信 向 理 


REN LI ZIYYAN GUAN LI XI TONG 


时 间 
“2009-02-27 16:46:48" 


图 13.6 ADODB 操作 结果 集 的 方法 


图 关键 技术 


当 使 用 execute0 函 数 执行 SQL 指令 时 ， 会 回 传 一 个 ADORecordSet 对 象 。 通 过 对 ADORecordSet 对 象 的 控 
制 ， 可 以 对 结果 集 进行 很 多 操作 。 操 作 结 果 集 的 方法 如 下 : 

(1) fields 

该 变量 保存 的 是 当前 指针 所 指向 的 记录 。 

(2) EOF 

该 变量 记录 当前 指针 是 否 指向 最 后 一 条 记录 。 如 果 是 ， 则 设 定 为 TRUE， 否则 为 FALSE。 

(3) GetArray([$number of rows]) 

返回 从 当前 指针 指向 的 记录 开始 ， 到 ($number_of rows 一 1) 行 的 全 部 记录 的 数组 。 参 数 $number_of rows 
表示 指定 的 记录 行 ， 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停 止 。 

(4) MoveNextO 

函数 作用 : 将 ADORecordSet (结果 集 ) 的 指针 下 移 一 位 。 如 果 成 功 ， 则 返回 TRUE， 和 否则 返回 FALSE。 

(5) Move($to) 

函数 作用 : 将 ADORecordSet (结果 集 ) 的 指针 移动 到 指定 位 置 。 如 果 $to 等 于 0， 则 指针 指向 结果 集 的 第 
一 条 数据 ， 如 果 $to 的 值 大 于 结果 集 ， 则 指针 指向 最 后 一 条 数据 。 注 意 ， 这 里 变量 $to 只 能 是 绝对 定位 。 

(6) MoveFirst() 

函数 作用 : 将 指针 移动 到 第 一 条 数据 ， 等 同 于 Move(0)。 

(7) MoveLast() 

函数 作用 : 将 指针 移动 到 最 后 一 条 数据 ， 等 同 于 Move(RecordCountO - 1) 

(8) FetchRow() 

函数 作用 : 返回 当前 指针 指向 的 记录 的 数组 ， 如 果 是 EOF， 回 传 FALSE。FetchRow0 不 能 和 “MoveNext() 
混用 。 

(9) FetchField($column number) 

函数 作用 : 返回 一 个 对 象 ， 包 含 字段 $column_number 的 名 称 、 空 间 长 度 等 相关 信息 。 

参数 $columm_number 是 要 查看 的 字段 名 称 。 

(10) FetchNextObject([$toupper=true]) 

函数 作用 : 返回 当前 指针 所 指向 的 记录 的 对 象形 式 ， 并 且 指 针 自 动 下 移 一 行 。 

参数 $toupper 如 果 等 于 TRUE， 则 字段 名 为 大 写 形式 。 

(11) FieldCountO 

函数 作用 : 返回 结果 集 里 的 字段 数 。 
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(12) RecordCount( ) 
函数 作用 : 返回 结果 集 里 的 记录 数 。 
(13) MetaType($nativeDBType [,$field max length],[$fieldobj]) 
函数 作用 : 标准 化 不 同 数据 库 系 统 下 的 数据 类 型 的 表示 法 。 处 理 不 同 的 数据 库 系统 有 一 个 问题 ， 即 每 一 个 
数据 库 系 统 对 于 相同 的 数据 类 型 会 有 不 同 的 表示 法 ， 比 如 支持 超 长 文本 的 类 型 ， 有 的 表示 为 text， 有 的 表示 为 
long character， 还 有 的 表示 为 clob 等 。MetaType0 函 数 可 以 将 这 几 种 表示 方法 统一 起 来 ， 如 用 大 写字 母 D 来 表 
示 所 有 的 日 期 类 型 ， 用 大 写字 母 T 表 示 所 有 的 时 间 类 型 。 
参数 说 明 : 
$nativeDBType: 数据 表 中 的 数据 类 型 。 
$fields_max_length: 字段 最 大 长 度 。 
$fieldsobj: 字段 对 象 。 
yp 
支持 char、varchar 等 字符 类 型 。 
支持 text、long character 等 长 类 型 。 
blob 或 binary image。 
日 期 date。 
时 间 timestamp。 
逻辑 类 型 和 位 类 型 。 
包含 编号 、 整 型 、 浮 点 型 等 数字 类 型 。 
包含 序列 、 自 动 增加 整数 等 序列 类 型 。 


图 设计 过 d 各 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_database13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 utf-8。 

(2) 创建 index.php 文件 ， 包 含 数 据 库 连接 文件 ， 定 义 SQL 查询 语句 ， 通 过 execute0 函 数 执行 查询 操作 ， 
通过 FieldCount 0 函数 统计 字段 数量 ,应 用 for 语 句 和 FetchField0 函 数 循环 输出 各 个 字段 的 值 ,并 应 用 metaTypeO 
函数 对 字段 中 的 数据 类 型 进行 判断 ， 同 时 应 用 DBDateO 函 数 对 时 间 进 行 格式 化 ， 其 关键 代码 如 下 : 


因 因 办 办 办 办 办 的 
ZFIGm%N 


<?php 

include_once 'conn/conn php’; /收入 数据 库 连 接 文件 

$count = 1; 

$sqlstr = 'select * from tb_object where id=" . Scount /SQL 查询 语句 

Srst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg 0 ): // 执 行 查 询 语句 

if (false != S$rst) { // 如 果 有 查询 结果 
for($i= 0; $i < Srst->FieldCount 0; $i++) { // 循 环 输出 各 个 字段 

Sfields = Srst->FetchField ( $i): /生成 字段 信息 对 象 
Stype = $fields->type; 

?> 

<td bgcolor="#FFFFFF"> 

<?php 

/从 对 象 中 获取 字段 的 类 型 信息 

if (Srst->metaType ( $type. - 1, $fields ) — "T") /如 果 标准 类 型 为 
echo $conn->DBDate ( $rst->fields [$i] ); /1/ 使 用 DBDate0 函 数 格式 化 时 间 

else 
echo S$rst->fields [$i]: // 如 果 是 其 他 类 型 ， 直 接 输 出 

?> 

<htd> 

<?php 

} 

} 

2 
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图 秘笈 心 法 


心 法 领悟 543: 操作 结果 集 方 法 的 运用 。 

在 本 实例 中 ， 只 是 使 用 FieldCount 0 函数 和 FetchField0 函 数 对 数据 表 中 的 字段 进行 操作 。 在 实例 544 中 ， 
将 应 用 EOF、fields 和 movenext0 函 数 以 及 while 语句 完成 数据 表 中 数据 的 循环 输出 ， 其 实现 的 是 结果 集中 行 的 
操作 。 


图 实例 说 明 

在 实例 533 中 介绍 了 很 多 操作 结果 集 的 方法 ， 本 实例 继续 应 用 上 一 实例 中 介绍 的 操作 结果 集 方 法 ， 对 数据 
表 中 的 行进 行 操作 ， 循 环 输出 数据 表 中 的 数据 。 同 时 应 用 一 个 新 的 方法 ， 实 现 对 结果 集 存 取 方 式 的 控制 ， 其 运 
行 结果 如 图 13.7 所 示 。 


用 户 信 息 
PARIS 
' 条 职 制 扣 果 委 5 六 ) 
' 1 
1 用户 名 时 间 
' mr 2010-04-02 ， 
， 明日 科 闪 2010-04-02 
' php 2010-04-03 ! 
: java 2010-04-03 1 
1 lavaScript 2010-04-03 1 
MOUND SEI 1 

主 曾 相配 


图 13.7 ADODB 类 库 中 对 数据 库 中 数据 输出 的 控制 


力 关键 技术 


在 通过 对 SQL 语句 的 操作 之 后 ， 多 数 都 会 返回 一 个 结果 集 (ADORecordSet 对 象 ) 。 通 过 对 ADORecordSet 
对 象 的 控制 ， 可 以 对 结果 集 进 行 各 项 操作 ， 这 里 介绍 的 是 如 何 控制 结果 集 的 存 取 方 法 。 
1. $ADODB_COUNTRECS 
当 该 变量 为 TRUE 时 ，RecordCount0 函 数 会 在 数据 库 驱 动 不 支 持 select 指令 返回 的 记录 总 数 时 进行 自动 模 
拟 ， 返 回 记 录 数 ， 默 认 值 为 TRUE。 每 次 进行 查询 操作 时 都 会 自动 检查 该 变量 的 值 。 此 功能 十 分 消耗 内 在 ， 不 
建议 使 用 。 
2. $SADODB_CACHE DIR 
该 变量 设置 缓存 目录 ， 一 般 在 使 用 缓存 函数 时 用 到 ， 如 CacheExecute0 函 数 。 
3.$ADODB_FETCH_MODE 
该 变量 决定 结果 集 以 哪 种 方式 进行 在 取 ， 有 4 个 值 : 
(1) define( ADODB FETCH DEFAULT'.0): 
(2) define( ADODB FETCH NUM.1) 
结果 集 以 字段 序号 为 索引 进行 存 取 ， 如 S$rst -> fields[0]、Srst -> fields[1]。 
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(3) define( ADODB FETCH ASSOC'?) 

结果 集 以 字段 名 称 为 索引 进行 存 取 ， 如 Srst -> fields[bigclass]、Srst -> fields[id]。 

(4) define( ADODB FETCH BOTH'3) 

结果 集 同时 支持 (2) 、 (3) 两 种 方式 。 如 果 未 设置 该 变量 ， 默 认 值 为 《1) ， 不 同类 型 的 数据 库 驱 动 默认 
值 也 不 相同 。 这 里 不 建议 使 用 变量 (4) ， 因 为 有 很 多 的 驱动 并 不 支持 。 
图 设计 过 程 

(1) 创建 conmn 文件 来， 编写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 


db _databasel13 数据 库 的 连接 , 应 用 $ADODB_FETCH_MODE 设置 结果 集 以 字段 名 称 为 索引 进行 存 取 , 并 设置 数 
据 库 的 编码 格式 为 utf-8， 其 代码 如 下 : 


<?php 

include_once (adodbs/adodb inc php): / 厂 入 adodbiniphp 文件 

$conn = ADONewConnection(mysql); /连接 MySQL 数据 库 

Sconn -> PConnect('localhost,'root,'111',db_database13"); /连接 db_database13 数据 库 

$ADODB FETCH MODE = ADODB FETCH ASSOC; // 设 置 结果 集 以 字段 名 称 为 索引 进行 存 取 
$conn -> execute('set names utf8"); /设置 编码 格式 


> 

(2) 创建 index.php 文件 ， 完 成 数据 的 循环 输出 。 首 先 ， 包含 数 据 库 连接 文件 。 然后， 定义 SQL 查询 语句 ， 
通过 execute0 函 数 执行 查询 操作 。 最 后 ， 通 过 while 语句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 

<?php 


include_once ‘conn/conn.pbp’; // 瞄 入 数据 库 连 接 文 件 
S$sqlstr = 'select * from tb_user where id limit 5 /SQL 查询 语句 
Srst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg 0 ); // 执 行 查询 语句 
while (! Srst->EOF ) { // wihle 语句 循环 输出 结果 
> 
<tr> 
<td width="126" height="30" align="center"><?php echo Srst->fields [user]: ?></td> 
<td width="117" align="center"><?php echo Srst->fields [dates]; ?></td> 
</t> 
<2php 
Srst->movenext |; /指针 下 移 
} 
Srst->close 0; // 关 闭 连接 
$conn->close (; 
?> 
图 秘笈 心 法 


心 法 领悟 544: 结果 集 存 取 方 式 的 选择 。 

在 关键 技术 中 已 经 对 ADODB 类 库 中 结果 集 的 存 取 方 式 进行 了 详细 介绍 ， 至 于 如 何 选择 ， 需 要 根据 实际 情 
况 具 体 分 析 ， 也 可 以 不 设置 结果 集 的 存 取 方 式 。 建 议 读 者 以 字段 名 称 为 索引 进行 数据 存 取 ， 这 样 在 获取 数据 值 
时 更 准确 一 些 ， 不 会 因为 数据 表 中 字段 的 添加 或 者 删除 而 影响 到 获取 的 值 。 


实例 545 


趣味 指数 : 伍 例 全 个 | 


图 实例 说 明 

在 实际 的 程序 开发 中 ， 如 果 要 实现 数据 在 不 同 数据 库 服 务 器 之 间 的 转换 ， 最 理想 的 方法 就 是 编写 一 个 数据 
转换 的 程序 。 这 就 是 本 实例 中 要 向 大 家 展示 的 内 容 ， 即 同时 连接 两 个 不 同 的 数据 库 服 务 器 ， 完 成 数据 由 MySQL 
数据 库 到 Access 数据 库 的 转换 。 运 行 本 实例 ， 单 击 图 13.8 中 的 “导出 ”按钮 ， 将 MySQL 数据 库 中 的 数据 导入 
到 Access 数据 库 中 ， 单 击 “ 查 看 ACCESS” 超 链接 将 看 到 如 图 13.9 所 示 的 存储 于 Access 数据 库 中 的 数据 。 
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9 
“I 人 管理 要 录 
| REN LT Hi YuaN GU LN TONG Y 镇 了 ACCESS 歼 据 库 中 的 数据 ”| 
EE 时 间 
2010.04.02 00:00:00 
2010-04-02 00:00:00 
2010-04-03 00:00:00 


2010-04-03 00:00:00 
2010-04-03 00:00:00 


本 版 权 所 有 


a et eae 
图 13.8 ”MySQL 数据 库 中 的 数据 图 13.9 ”Access 数据 库 中 的 数据 


图 关键 技术 


一 次 连接 两 个 数据 库 ， 即 同时 执行 两 次 ADONewConnection0 函 数 和 PConnectO 函 数 ， 分 别 指定 不 同 的 
MySQL 数据 库 服务 器 和 Access 数据 库 服务 器 。 

在 连接 MySQL 服务 器 时 ， 设 置 的 用 户 名 是 root， 密 码 是 111， 指 定 的 数据 库 是 db_database13， 设 置 编码 格 
式 为 utf-8。 

在 连接 Access 服务 器 时 ， 指 定 的 数据 库 是 db_database13.mdb， 注 意 这 里 必须 设置 Access 数据 库 文件 在 服 


务 器 中 的 绝对 路 径 。 
同时 连接 两 个 数据 库 的 代码 如 下 : 
<?php 
include_once('../adodbs/adodb.inc.php); / 工 入 (include) adodb.inc.php 文件 
S$conn = ADONewConnection(mysql); // 建 立 连接 
$conn -> PConnect(localhostvroot"111vdb_database137); // 连 接 数 据 库 
S$conn -> execute('set names utf8"); // 设 置 编码 格式 
S$con = ADONewConnection("access"); /连接 Access 数据 库 
S$con-> PConnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=F:\AppServ\www\imr\13\W008\\conn\\data\\db_database13.mdb"); 
$con-> execute('set names gb2312): /设置 编码 格式 


将 从 MySQL 数据 库 中 读 取 的 数据 添加 到 Access 数据 库 中 ， 应 用 的 是 ADODB 类 库 中 的 GetmsertSQLO 函 
数 ， 该 函数 用 于 向 数据 库 中 添加 新 的 记录 ， 其 语法 如 下 : 


GetInsertSQL(&$rs, $arrFields) 
参数 $rs 设置 要 添加 记录 的 结果 集 ; 参数 $arFields 设置 新 记录 的 字段 值 及 字段 名 称 。 
力 设计 过 程 


(1) 创建 comn 文件 ， 编 写 conn.php 文件 ， 完 成 与 两 个 数据 库 服务 器 的 连接 ， 其 代码 请 参考 关键 技术 中 的 
内 容 。 

(2) 创建 index.php 文件 , 将 从 MySQL 数据 库 中 读 取 出 的 数据 通过 GetInsertSQLO 函 数 添加 到 Access 数据 
库 中 ， 并 且 在 本 页 中 输出 MySQL 数据 库 中 的 数据 ， 同 时 创建 导出 和 查看 Aceess 数据 库 中 数据 的 超 链接 ， 其 关 
键 代 码 如 下 : 


<?php 

include ("conn/conn.php"): 

$sql = "select * from tb_user where id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die ( 'error: '. Sconn->errorMsg 0 ); /执行 查询 语句 


Sarray = array 0: 
while (! $rst->EOF ) { 
Sarray [id] = S$rst->fields [id]; # process $arr 
Sarray [user]= iconv ( "utf-8", "gb2312", Srst->fields [user] ): # process Sarr 
Sarray [pass'] = Srst->fields [pass]:# process $arr 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 关键 技术 


ADODB 中 的 SelectLimitO 函 数 模拟 limit 关键 字 ， 控 制 select 查询 语句 的 执行 。 但 要 注意 ，SelectLimit0 函 
数 的 参数 位 置 与 MySQL 数据 库 中 limit 关键 字 是 不 同 的 。SelectLimitO 函 数 的 语法 如 下 : 
SelectLimit($sql[.$numrows=1][.$offset=-1][.$Sinputarr=false]) 
参数 说 明 : 
$sql: 要 执行 的 select 查询 语句 。 
$numrows: 要 查询 的 记录 数 。 如 果 该 值 为 -1， 则 查询 到 最 后 一 条 记录 。 
$offset: 表示 从 第 几 条 记录 开始 查询 。 
$inputarr: 结合 变量 。 
图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 服务 器 中 db_database13 数据 库 的 
(2) 创建 ndex.php 文件 ， 包 含 数据 库 连 接 文件 ， 定 义 SQL 查询 语句 ， 应 用 SelectLimitO 函 数 查询 出 班级 
前 3 名 学 生 的 成 绩 ， 并 且 循 环 输出 查询 结果 ， 其 关键 代码 如 下 : 


<?php 

include_once (conn/conn.php’); // 载 入 adodb iniphp 文件 
$sql="select * from tb_student where id order by grade desc"; // 定 义 查 询 语句 
Snumrows = 3; /设置 查询 的 记录 数 
Soffset = 0; /设置 起 始 位 置 


Srst = $conn -> SelectLimit($sql, $numrows,$offset) or die(execute error: '.$conn -> ErrorMsgO): /执行 查询 
while(!$rst -> EOF){ 
?> 
<t> 
<td height="25" align="center"><?php echo Srst -> fields[studentname'1:?></td> 
<td align="center"><?php echo Srst -> fields['classname']; ?></td> 
<td align="center"><?php echo Srst -> fields['grade]; ?></td> 
<?php 
Srst -> movenextO; /指针 下 移 
} 
Srst -> close(); /关闭 连接 
$conn -> close(); 
?> 


图 秘笈 心 法 


心 法 领悟 546: 明确 SelectLimit0 函 数 与 MySQL 数据 库 中 limit 关键 字 的 区 别 。 
在 SelectLimit0 函 数 中 ，$numrows 指定 的 是 要 查询 的 记录 数 ， 而 $offset 指定 从 第 儿 条 记录 开始 查询 ， 而 在 
MySQL 数据 库 中 ，limit 关键 字 指 定 查 询 的 开始 位 置 ， 而 offset 指定 查询 的 记录 数 。 


实例 547 


图 实例 说 明 
在 ADODB 类 库 中 ， 有 一 种 方法 可 以 返回 表格 式 的 结果 集 ， 即 将 查询 结果 直接 以 表格 的 形式 进行 输出 。 本 
实例 就 应 用 这 种 方法 循环 输出 编程 词典 的 数据 ， 其 运行 结果 如 图 13.11 所 示 。 
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图 13.11 ADODB 生成 HIML 表格 


图 关键 技术 


本 实例 应 用 rs2html0 函 数 ， 返 回 一 个 HTML 表格 格式 的 结果 集 ， 其 语法 如 下 : 
fonction rs2html(Sadorecordset [Stableheader attributes]. [Scol_titles]) 

参数 说 明 : 

$adorecordset: 要 返回 的 结果 集 。 

$tableheader attributes: 对 表格 的 参数 及 属性 的 设置 。 

$col titles: 对 字段 的 重新 命名 。 

要 运用 本 函数 ， 必 须 载 入 adodb 类 库 中 的 tohtmlinc.php 文件 。 


图 设计 过 程 
(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 定 义 SQL 查询 语句 ， 应 用 rs2html0 函 数 将 查询 结果 以 表 
格 的 形式 输出 ， 其 关键 代码 如 下 : 
<?php 


include_once ‘conn/conn. php'; // 虐 入 数据 库 链接 文件 


include_once '../adodbs/tohtml.inc.php'; / 夏 入 tohtmlinc php 文件 
Srst = $conn -> execute('select + from tb_bccd); // 返 回 查询 结果 集 


rs2html($rst,' width="775" border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#CCCCCC",array( 序 号 ', 名 称 ', 类 别 "," 时 间 
); 
> 


图 秘笈 心 法 


心 法 领悟 547: rs2html0 函 数 。 

这 是 一 个 独立 的 函数 (rs2heml = recordset to html) ， 相 当 于 PHP 中 的 odbc_ result_all0 函 数 。 它 输出 一 个 完 
整 的 ADORecordSet， 参 数 $adorecordset 如 同一 个 HTML 表格 ; 参数 gtableheader_ attributes 允许 控制 表格 中 的 
参数 ， 例 如 cellpadding、cellspacing 或 者 border 等 属性 。 最 后 ， 通 过 $col titles 参数 ， 设 置 数据 表 中 字段 的 名 称 。 
注意 ， 该 函数 是 一 种 快速 除 错 机 制 ， 并 不 是 一 个 理想 的 结果 集 输出 方法 。 


高 级 
趣味 指数 : 丛 食 食 侧 : 


力 实例 说 明 


在 ADODB 中 , 有 一 种 方法 可 以 将 结果 集中 的 数据 直接 
以 下 拉 列 表 框 的 形式 返回 , 这 种 方法 非常 适合 论坛 中 帖子 标 
题 或 者 类 别 的 输出 ， 也 可 以 在 登录 用 户 的 权限 选择 中 使 用 。 
在 本 实例 中 , 应 用 这 种 方法 完成 用 户 登 录 时 编程 词典 类 型 的 
选择 ， 其 运行 结果 如 图 13.12 所 示 。 


图 13.12 ADODB 生成 下 拉 列表 框 
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图 关键 技术 


ADODB 中 生成 下 拉 列 表 框 应 用 的 是 GetMenu0 函 数 。 

GetMenu0 函 数 ， 返 回 一 个 HTML 下 拉 列 表 框 (select) 。 结 果 集 的 第 一 列 (fields[0])， 被 显示 到 下 拉 列 表 
当中 。 第 二 列 〈fields[1]) 被 设置 为 <option> 标 签 的 value 属性 ， 其 语法 如 下 : 

GetMenu(Sname, [Sdefanlt_str="], [SblanklstIten=true], [Smultiple select-false], [$size=0], [SmoreAtt 

参数 说 明 : 

$name: 下 拉 列 表 框 的 名 称 。 

$default_str: 如 果 $default_ str 的 值 等 于 其 中 一 个 fields[0]， 那 么 这 个 fields[0] 就 是 该 下 拉 列 表 的 默认 选项 。 
相当 于 为 这 个 fleds[0] 添 加 了 属性 <selected>。 

$blank: 该 参数 默认 值 为 tue。 在 生成 下 拉 列 表 框 时 ， 第 一 行 选 项 默认 为 室 ， 即 <option></option>。 如 果 为 
false， 则 没有 默认 的 空 选项 。 

$multiple_select: 是 否 支持 多 选 ， 默 认 值 为 false， 即 不 允许 。 

$size: 选取 列表 框 的 大 小 ， 默 认为 0， 生 成 一 个 下 拉 列 表 。 如 果 $size 的 值 大 于 0， 则 生成 一 个 列表 框 。 

$moveAttr: 该 参数 可 以 增加 列表 框 的 属性 ， 如 添加 一 个 javascript 脚本 等 。 


设计 过 程 
(1) 创建 com 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 编写 index.php 文件 ， 创 建 form 表单 ， 设 置 action 属性 值 为 index_ok.php。 包 含 数 据 库 连接 文件 ， 定 
义 SQL 查询 语句 ， 应 用 GetMenu20 函 数 将 查询 结果 以 下 拉 列 表 框 的 形式 输出 ， 其 关键 代码 如 下 : 


<?php 

include_once 'conn/conn.php'; / 夏 入 数据 库 连 接 文件 
$sqlstr = 'select name,id from tb_becd'; //SQL 查询 语句 

Srst = $conn -> execute($sqlstr) or die('execute error: '.$conn -> errorMsgO): /执行 查询 语句 ， 返 回 结果 集 
> 


<!-- 调用 getMenu20 函 数 -> 
<?php echo Srst -> getMenu2(type`S_POST[name].falsej: ?> 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 完 成 用 户 的 登录 操作 。 


图 秘笈 心 法 


心 法 领悟 548: 生成 下 拉 列 表 框 的 另 一 个 函数 一 一 GetMenu20。 

在 本 实例 中 ， 我 们 运用 的 并 不 是 关键 技术 中 讲解 的 GetMenu0 函 数 ， 而 是 GetMenu20 函 数 。GetMenu20 函 
数 的 作用 与 GetMenu0 函 数 相 同 ， 它 们 之 间 的 区 别 是 : GetMenu0 中 的 参数 $default_str 和 fields[0] 比 较 ， 如 果 相 
等 ， 那 么 fields[0] 就 是 这 个 下 拉 列 表 的 默认 选项 ， 而 getMenu20 中 的 参数 $default_str 则 是 和 fields[1] 进 行 比较 ， 
其 他 不 变 。 


图 实例 说 明 


事务 处 理 机 制 在 程序 开发 过 程 中 有 着 非常 重要 的 作用 ， 它 可 以 使 整个 系统 更 加 安全 ， 例 如 在 银行 处 理 转账 
业务 时 ， 如 果 A 账户 中 的 金额 刚 被 发 出 ,而 B 账户 还 没 来 得 及 接受 就 发 生 停电 事故 ， 这 会 给 银行 和 个 人 带 来 很 
大 的 经 济 损失 。 采 用 事务 处 理 机 制 ， 一 旦 在 转账 过 程 中 发 生意 外 ， 则 程序 将 回 滚 ， 不 做 任何 处 理 。 在 本 实例 中 ， 
沿用 实例 545 的 内 容 ， 实 现 数 据 在 不 同 数据 库 间 的 转换 功能 ， 在 将 MySQL 数据 库 中 的 数据 转换 到 Access 数据 
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库 中 后 ， 删 除 MySQL 数据 库 中 的 原始 数据 ， 并 应 用 事务 处 理 机 制 保证 数据 转换 操作 安全 、 顺 利 地 进行 。 运 行 
本 实例 ， 如 图 13.13 所 示 ， 单 击 “ 数 据 转移 ” 超 链 接 ， 将 MySQL 数据 库 中 的 数据 转移 到 Access 数据 库 中 ， 并 
且 删 除 MySQL 数据 库 中 的 原始 数据 。 单 击 “ 查 看 ACCESS” 超 链接 ， 将 查看 到 Access 数据 库 中 存储 的 数据 ， 
如 图 13.14 所 示 。 


图 13.13 数据 转移 图 13.14 查看 Access 数据 库 中 的 数据 


图 关键 技术 


在 ADODB 中 ， 事 务 处 理应 用 的 是 如 下 3 个 函数 : 

(1) BeginTrans0 函 数 ， 开 启事 务 处 理 。 该 函数 和 下 面 的 两 个 函数 都 是 应 用 在 PHP 的 事务 处 理 中 。 

(2) CommitTrans0 函 数 ， 如 果 成 功 完成 数据 库 操作 ， 则 执行 该 函数 。 

(3) RollbackTrans0 函 数 ， 结 束 一 次 操作 ， 恢 复 操作 前 的 所 有 改变 。 成 功 返 回 TRUE， 如 果 服 务 器 不 支持 
返回 FALSE。 
图 设计 过 程 

(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 

(2) 编写 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 定 义 SQL 语句 ， 循 环 输出 MySQL 数据 库 中 的 数据 ， 通 
过 BeginTrans0 函 数 开启 事务 处 理 。 然 后 ， 根 据 超 链接 传递 的 参数 进行 判断 ， 通 过 GetInsertSQLO 函 数 执行 数据 
的 转移 操作 ， 转 移 成 功 后 通过 delete 语句 删除 原始 数据 库 中 的 数据 。 最 后 ， 根 据 添加 语句 和 删除 语句 的 执行 情 
况 ， 判 断 是 执行 CommitTrans 0 提交 操作 ， 还 是 执行 RollbackTrans 0) 回 滚 操作 ， 其 关键 代码 如 下 : 


<?php 

include ("conn/conn.php"): 

$sql = "select * from tb_user where id order by id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die ( 'error: '. $conn->errorMsg (0 ); /执行 查询 语句 
Sarray = array (; 

$con->BeginTrans (0; /开始 事务 处 理 
二 /开始 事务 处 理 


while ( ! Srst->EOF ) 
if($ es "数据 转移 ") { 
Sarray ['id'] = $rst->fields id]: # process $arr 
Sarray [user] = iconv ( "utf-8", "gb2312". Srst->fields [user] ): # process $arr 
Sarray [pass'] = $rst->fields ['pass']; # process $arr 
Sarray ['dates'] = $rst->fields ['dates']: # process $arr 


$sqls = "select + from tb_user where id=0 ": /| 创建 SQL 语句 
Sret = $con->execute ( $sqls ) or die ( ‘error: eee /| 执行 查询 语句 
Sinsert = $con->getInsert SQL ( $ret. $array ) or die ( ‘update error: '. $con->errorMsg 0 ): /添加 新 数据 
Sresult=$con->execute ( $insert ); 
$sql = 'delete from tb_user where id =. $rst->fields [id]: /SQL 删除 语句 
Sresults = $conn->execute ( $sql ) or die ( ‘execute error: '. $conn->ErorMsg 0 ); /执行 删除 语句 
} 

?> 

<h> 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<?php 


error Teporting(E_ALI): // 显 示 所 有 的 错误 信息 

include once ('../adodb5/adodb-errorhandler.inc.php): 

include_once ('../adodb5/adodb.inc.php): / 夏 入 adodb.iniphp 文件 
S$conn = ADONewConnection(mysql): /和 连接 MySQL 数据 库 

$conn -> PConnect(localhost,root"111',db_database137): /连接 db_database13 数据 库 
/ISADODB FETCH MODE = ADODB FETCH ASSOC: // 设 置 结果 集 以 字段 名 称 为 索引 
en > execute('set names utf8"); // 设 置 编码 格式 


.2 纺 写 index.php 文件 。 首先 , 包含 数据 库 连 接 文件 。 然后 , 定义 SQL 语句 , 通过 execute0 函 数 执 行 SQL 
语句 。 最 后 ， 循 环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<?php 
include ("conn/conn.php"); 
$sql = "select + from tb_use where id limit 5 "; /| 创建 SQL 语句 
Sret = $conn -> execute($sql); /| 执行 查询 语句 
while ( ! $ret->EOF ) { /循环 输出 

> 

<tr> 


<td height="20"><?php echo S$ret->fields[0]; ?></td> 
<td height="20"><?php echo S$ret->fields[1]; ?></td> 
<td><?php echo $ret->fields[3]; ?></td> 


Sret->movenext (); /指针 下 移 


3 
Sret->close |; // 关 闭 连接 


?> 
图 秘笈 心 法 

心 法 领悟 552: 通过 error_reporting0 函 数控 制 返回 的 错误 信息 。 

在 本 实例 中 ， 设 置 error_reporting0 函 数 的 值 为 E_ALL 返回 所 有 的 错误 信息 。 如 果 将 值 设置 为 0， 将 不 会 有 
任何 错误 信息 输出 。 如 果 想 更 多 地 了 解 error_reporting0 函 数 ， 请 参考 PHP 函数 手册 。 
训 | 
趣味 指教， 请 户 商 商 


图 实例 说 明 

在 实例 552 中 , 只 是 应 用 ADODB 类 库 中 提供 的 自 定义 错误 处 理 a 
机 制 返 回 所 有 的 错误 信息 ， 在 本 实例 中 将 介绍 另外 一 种 错误 处 理 机 。 局 TDie 一 
制 ， 不 但 可 以 返回 错误 信息 ， 而 且 可 以 将 错误 信息 存储 到 指定 的 文件 csteee sen toese were Yn 5 
中 。 在 本 实例 中 , 将 返回 的 错误 信息 存储 于 根 目录 下 error 文件 夹 中 ， i a 
errorlog 中 的 错误 信息 如 图 13.18 所 示 。 人 


力 关键 技术 


同样 ， 应 用 ADODB 中 提供 的 自 定义 错误 处 理 机 制 时 ， 必 须 在 程序 连接 数据 库 服务 器 之 前 载 入 adodb- 
errorhandler.inc.php 文件 。 

将 错误 信息 存储 于 指定 的 文件 中 ， 应 用 的 是 两 个 选择 性 常量 : ADODB_ ERROR LOG TYPE 和 ADODB_ 
ERROR LOG DEST. 

将 ADODB ERROR LOG TYPE 的 值 设置 为 3， 即 将 错误 信息 存储 于 常量 ADODB_ERROR LOG DEST 
指定 的 文件 中 。 这 里 指定 ADODB ERROR LOG DEST 的 值 为 error/error.log， 即 将 错误 信息 存储 于 实例 根 目 录 
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下 error 文件 夹 的 error.log 文件 中 。 
图 设计 过 程 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 。 首 先 ， 定 义 两 个 常量 ， 设 置 程序 中 错误 信息 的 存储 位 置 。 然 
后 ， 载 入 adodb-errorhandler.inc.php 文件 。 最 后 ， 完 成 与 MySQL 数据 库 的 连接 ， 其 代码 如 下 : 


<?php 

define(ADODB_ERROR_ LOG TYPE'3); /设置 类 型 
define(ADODB_ ERROR LOG DEST'.error/error.log’); /设置 存储 路 径 
include_once (adodbs/adodb-errorhandlerinc php); / 怀 入 自 定义 错误 处 理 文件 
include_once (adodbs/adodb inc php?): / 怀 入 adodb.iniphp 文件 
$conn = ADONewConnection(mysql); /连接 MySQL 数据 库 
Sconn -> PConnect('localhost,'root,'111',db_database13); /连接 db_database13 数据 库 
Sconn -> execute('set names utf8'); // 设 置 编码 格式 

> 


(2) 编写 index.php 文件 。 首先 , 包含 数据 库 连接 文件 。 然后 , 定义 SQL 语句 , 通过 execute0 函 数 执行 SQL 


语句 。 最 后 ， 循 环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 
<?php 


include ("conn/conn.php"); 
$sql = "select + from tb_use where id limit 5 "; // 创 建 SQL 语句 
Sret = $conn -> execute($sql); /| 执行 查询 语句 
while (! $ret->EOF ) { /循环 输出 

> 

<t> 


<td height="20"><?php echo $ret->fields[0]; ?><htd> 
<td height="20"><?php echo $ret->fields[1]; ?></td> 
<td><?php echo $ret->fields[31; ?></td> 
<t> 
<?php 
Sret->movenext |; /1/ 指 针 下 移 
} 


Sret->close 0; // 关 闭 连接 
$conn->close (); 
?> 


图 秘笈 心 法 


心 法 领悟 553: ADODB_ERROR_LOG _TYPE 常量 设置 错误 记录 的 类 型 。 

用 ADODB_ERROR_LOG _ TYPE 常量 设置 错误 记录 的 类 型 ， 可 选 值 如 下 : 

0， 默 认 值 。 根 据 php.ini 文件 中 的 error_log 配置 ， 错 误 被 发 送 到 服务 器 日 志 系 统 或 文件 。 
1， 错 误 被 发 送 到 destination 参数 中 的 地 址 。 只 有 该 类 型 使 用 headers 参数 。 

回 2， 通 过 PHP debugging 连接 来 发 送 错 误 。 该 选项 只 在 PHP 3 中 可 用 。 

加 ”3， 错 误 被 发 送 到 文件 目标 字符 串 。 


加 


加 


13.4 ADODB 操作 数据 库 
高 级 | 
趣味 指数 : 由本 在 


力 实例 说 明 


虽然 PHP 是 构建 Web 系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函数 一 直 没有 标准 化 ， 不 同 数 据 库 间 的 函数 
名 称 、 参 数 差异 很 大 ， 在 更 换 数据 库 时 ， 会 带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 数 
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据 库 函数 间 的 差异 ， 让 开发 者 可 以 很 简单 地 去 切换 数据 库 ， 这 就 是 ADODB 类 库 。 
本 实例 中 ， 应 用 ADODB 访问 Access 数据 库 ， 并 通过 分 页 函数 ， 实 现 数 据 库 中 数据 的 分 页 输出 ， 
果 如 图 13.19 所 示 。 


中 
了 
EN 


个 长 为 囊 臣 ”四 收藏 本 站 岛 联系 我 们 


日 当 击 位 置 》 育 页 > 图 书 列表 


图 书 名 称 出 版 社 页 友 价格。 出 疡 时 间 。 Im 
在 saal Jasie 工 程 友 用 与 天 目 实 器 机械 工业 出 版 社 28 与 ZF 1 
5 工程 应 用 与 项 目 实 哈 机柜 工业 出版 社 30 3 2 和 F2 12 


Dol 工程 用 与 有人 史 宙 柜 工业 岂 版 社 T0013 
二 首页 上 -页 下 -页 屋 页 


图 13.19 ADODB 分 页 输出 Access 数据 库 中 的 数据 


力 关键 技术 


应 用 ADODB 操作 Access 数据 库 最 简单 的 方法 就 是 应 用 在 实例 538 和 实例 539 中 定义 的 ADODB 连接 和 操 
作 数 据 库 类 。 
本 实例 的 目的 是 让 读者 更 深刻 地 理解 ADODB 操作 Access 数据 库 的 方法 和 步骤 ， 如 下 所 示 : 
(1) 载 入 adodb.inc.php 文件 ， 这 是 应 用 ADODB 类 库 操作 任何 数据 库 的 前 提 。 
(2) 连接 Access 数据 库 服 务 器 ， 依 然 应 用 ADONewConnection0 函 数 ， 只 是 其 参数 值 是 Access。 
(3) 应 用 PConnect0 函 数 连接 指定 的 数据 库 文件 。 这 是 Access 数据 库 与 其 他 数据 库 不 同 的 地 方 ， 数据 库 文 
件 的 位 置 必须 是 一 个 绝对 路 径 。 
(4) 设置 数据 库 的 编码 格式 。 


ADODB 连接 Access 数据 库 的 关键 代码 如 下 : 
<?php 


include('../adodb5/adodb.inc.php); / 夏 入 (include) adodb.inc.php 文件 

Sconn = ADONewConnection('access)); /连接 Access 数据 库 

$conn-> PConnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=F:\AppServ\www\imr\13\W017\\data\\db_database13.mdb"); 
S$conn -> execute('set names gb2312"); // 设 置 编码 格式 

> 


(5) 根据 连接 数据 库 成 功 返 回 的 对 象 ， 执 行 查询 语句 ， 完 成 数据 的 分 页 输出 ， 有 关 数 据 的 分 页 输出 方法 请 
读者 参考 实例 540 和 实例 341， 这 里 不 再 歼 述 。 
图 设计 过 程 

(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 。 连 接 Access 数据 库 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 


(2) 创建 index.php 文件 。 首 先 ， 包 含 数据 库 连接 文件 ， 载 入 tohtmlinc.php 文件 。 然 后 ， 定 义 SQL 语句 ， 
定义 分 页 变量 。 最 后 ， 应 用 分 页 函数 完成 数据 的 分 页 输出 ， 其 关键 代码 如 下 : 


<?php 
include("conn/conn .php"): /收入 数据 库 连 接 文件 
include('./adodb$/tohtml.inc.php); / 厂 入 tohtmline.php 文 件 
$sql = 'select * from tb_bookinfo'; /查询 语句 
Snum =10; /每 页 显示 的 记录 数 
ifisset($_GET[m page])){ / 漳 断 当前 页 码 

$c page=$ GET[n page]: // 将 $n_page 赋 给 变量 Sc_apge 
Jelse{ 

$c page 一 1 // 初 始 化 变量 $c_page 


和 

Srst= $conn -> PageExecute(Ssql.Snunm.Sc_ page): /执行 PageExecute 函数 

Ts2html($rst'width=810 bordercolor=#FFFFFF 'array( 图 书 名 称 '"" 出 版 社 " 页 码 '… 价 格 "出 版 时 间 '.TD7): 

> 

<table width="520" height="24" border="0" cellpadding="0" cellspacing="0" bordercolor="#FFFFFF" bgcolor—"#999999"> 
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<t> 
<td><font color=#999999> 当 前 是 第 <?php echo $rst -> absolutePage0: ?> 页 /一 共 是 <?php echo Srst -> LastPageNo0: ?> 页 </font></td> 
<td align="center" bgcolor="#FFFFFF"> 


<?php 
if(false ! 一 Srsb{ 
这 !$Srst -> AtfirstPageO){ /如 果 当 前 页 不 是 首页 


人 

<!-- 输出 向 上 翻 页 超 链接 -> 

<a href="<?php echo ?n pge-1 ?>"> 首页 </a> 

<a href ="<?php echo ?n_page=.($rst -> absolutePage0 - 1); ?>"> 上 一 页 </a> 
要 


这 !$Srst -> AtlastPageO){f /如 果 当 前 页 不 是 尾 页 


> 

<!-- 输出 向 下 翻 页 超 链接 _--> 
<a href = "<?php echo ?n_page=.($rst -> absolutePage0 + 1); ?>"> 下 一 页 </a> 
<a href ="<?php echo ?n_page='(Srst -> LastPageNo0):?>"> 尾 页 </a> 


> 


力 秘笈 心 法 


心 法 领悟 554: ADODB 操作 Access 数据 库 必 须 注意 的 问题 。 

在 连接 数据 库 时 ， 指 定 的 Access 数据 库 文件 的 存储 位 置 必须 是 绝对 路 径 。 另 外 ， 从 Access 数据 库 中 读 取 的 
数据 要 使 用 gb2312 编码 ， 不 可 以 使 用 UTF 编码 格式 。 如 果 页 面 中 使 用 的 是 utf-8 编码 ， 那 么 可 以 在 输出 数据 时 
应 用 iconv0 函 数 对 字符 串 的 编码 格式 进行 转换 。 


趣味 指数 : 容 全 食 价 | 


图 实例 说 明 


本 实例 介绍 应 用 ADODB 访问 MySQL 数据 库 ， 并 且 通过 while 语句 循环 输出 数据 库 中 的 数据 , 运行 结果 如 
图 13.20 所 示 。 
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图 13.20 ADODB 访问 MYSQL 数据 库 
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图 关键 技术 


在 本 实例 中 ， 应 用 ADONewConnection0 函 数 连接 数据 库 服务 器 ， 应 用 PConnect0 函 数 连接 db_database13 
数据 库 ， 设 置 用 户 名 为 root， 密 码 为 111， 设 置 数据 库 编码 格式 为 utf-8。 
通过 execute0 函 数 执行 SQL 语句 ， 在 while 循环 语句 中 , 应 用 EOF 判断 指针 位 置 ， 应 用 fields0 函 数 获取 数 
据 表 中 对 应 字段 的 值 ， 应 用 movenext0 函 数控 制 指针 的 移动 。 
本 实例 中 应 用 的 函数 请 读者 参考 实例 543 和 实例 544 关键 技术 中 的 内 容 ， 这 里 不 再 袭 述 。 
图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 创建 ndex.php 文件 。 首先 , 包含 数据 库 连接 文件 。 然后, 定义 SQL 语句 , 通过 execute0 函 数 执行 SQL 
语句 。 最 后 ， 通 过 while 循环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<?php 

include_once (‘conn/conn.php); / 厂 入 (include) adodb inc.php 文件 
S$sqlstr = 'select * from tb_bccd'; /| 创建 SQL 语句 

Srst = $conn -> execute($sqlstr) or die('connect error’); /| 执行 SQL 语句 ， 查 询 出 这 等 于 2 的 数据 
while(!$rst -> EOF){ /1 wihle 语句 循环 输出 结果 

> 


<t> 
<td height="20" bgcolor="#FFFFFF"><?php echo Srst -> fields['id]:?></td> 
<td bgcolor="#FFFFFF"><?php echo Srst -> fields['name']:?></td> 
<td bgcolor="#FFFFFF"><?php echo Srst -> fields['type]:?></td> 
<td bgcolor="#FFFFFF"><?php echo Srst -> fields[dates]:?></td> 


<t> 
Srst -> movenext|; /| 指针 下 移 
} 
Srst -> close0; /关闭 连 接 
Sconn -> closeO; /关闭 数据 库 
> 
图 秘笈 心 法 


心 法 领悟 555: 选择 适合 的 ADODB 操作 数据 库 方法 。 

在 实际 的 Web 程序 开发 过 程 中 , 建议 读者 应 用 实例 538 和 实例 539 中 封装 的 ADODB 连接 和 操作 数据 库 类 
来 实现 对 数据 库 的 操作 。 因 为 这 种 方法 更 适合 对 数据 库 的 管理 、 维 护 和 更 新 ， 一 旦 出 现 更 换 数 据 库 服务 器 的 问 
题 也 容易 解决 。 本 实例 中 介绍 的 单一 的 数据 库 连接 、 操 作 方法 ， 存 在 一 定 的 局 限 性 ， 更 适合 于 读者 在 学 习 阶 段 
使 用 ， 以 了 解 ADODB 操作 数据 库 的 函数 和 步骤 。 


实例 556 SQL Server 数据 库 高 级 


力 实例 说 明 


本 实例 介绍 应 用 ADODB 访问 SQL Server 数 据 库 , 并 且 通 过 while 
循环 语句 输出 数据 库 中 的 数据 , 其 中 还 应 用 $ADODB FETCH MODE 
变量 控制 结果 集 的 存储 方式 ， 运 行 结果 如 图 13.21 所 示 。 


图 关键 技术 


通过 ADODB 访问 SQL Server 数据 库 的 操作 步骤 与 实例 555 应 ”图 13.21 ADODB 访问 SQL Server 数据 库 
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用 ADODB 访问 MySQI 数据 库 是 相同 的 ， 这 里 就 不 再 袭 述 ， 唯 一 的 区 别 是 在 访问 SQL Server 数据 库 时 ， 应 用 
$ADODB FETCH MODE 变量 对 结果 集 的 存 取 方式 进行 控制 。 
$ADODB_FETCH_MODE 变量 决定 结果 集 以 哪 种 方式 进行 存 取 ， 有 关 该 变量 的 详细 讲解 请 参考 实例 544。 
在 通过 ADODB 连接 SQL Server 数据 库 时 还 有 一 点 需要 注意 , 即 在 通过 PConnect0 函 数 连 接 数 据 库 文件 时 ， 
对 Server 服务 器 的 设置 。 如果 SQL Server 数据 库存 储 于 本 机 中 , 那么 Server 的 参数 值 可 以 使 用 localhost。 但 是 ， 
如 果 SQL Server 数据 库存 储 在 其 他 机 器 中 ， 那 么 Server 的 参数 值 必须 是 SQL Server 的 服务 器 名 称 。 


图 设计 过 程 

(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 SQL Server 数据 库 的 连接 ， 并 且 设置 以 字段 名 称 为 结 
果 集 索引 。 

(2) 编写 index.php 文件 。 首 先 ,包含 数据 库 连 接 文件 。 然 后 , 定义 SQL 语句 , 通过 execute0 函 数 执行 SQL 
语句 。 最 后 ， 循 环 输出 SQL Server 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<?php 
include_once("conn/conn.php"); 


S$sqlstr = "select * from tb_goods where addtime='2009-5-23' // 创 建 SQL 语句 
Srst = $conn -> execute($sqlstr) or die('connect error’): /执行 SQL 
while(!$rst -> EOF){ /如果 没 有 错误 ， 则 配合 wihle 循环 输出 结果 
> 
<t> 


<td align="left" bgcolor="#FFFFFF">&nbsp;<?php echo iconvCgb2312vutf-8".Srst -> fields['name']):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo S$rst -> fields['addtime']:?></td> 

<td align="left" bgcolor="#FFFFFF">&nbsp;<?php echo $rst -> fields['counts]:?></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo Srst -> fields['price]:?></td> 


hp 
Srst -> movenext(); /指针 下 移 
Srst -> close(); // 关 闭 连接 


秘笈 心 法 

心 法 领悟 556: 了 解 ADODB 操作 数据 库 的 方法 和 步骤 。 

在 本 节 的 3 个 实例 中 ， 分 别 介绍 了 如 何 通 过 ADODB 操作 Access、MySQL 和 SQL Server 数据 库 ， 其 目的 
是 让 读者 对 ADODB 中 操作 数据 库 的 方法 和 步骤 有 一 个 系统 的 了 解 ， 从 中 读者 可 以 体会 到 ， 无 论 是 操作 哪 种 数 
据 库 ， 所 使 用 的 方法 和 操作 步骤 基本 都 是 相同 的 ， 这 就 是 ADODB 类 库 的 强大 之 处 ， 这 也 就 是 笔者 为 什么 推崇 
在 实际 的 程序 开发 过 程 中 使 用 实例 538 和 实例 539 中 封装 的 类 来 连接 和 操作 数据 库 的 原因 。 
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14.1 环境 搭建 


力 实例 说 明 


PHP 没有 内 置 Smarty 模板 类 ， 需 要 单独 下 载 和 配置 ， 并 且 Smarty 要 求 服务 器 上 的 PHP 版 本 最 低 为 4.0.6。 
用 户 可 以 去 网 站 http://smarty.net/download.php 下 载 最 新 的 Smarty 压缩 包 。 本 书 使 用 的 版 本 是 Smarty-2.6.23， 下 
载 地址 如 图 14.1 所 示 。 
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图 14.1 Smarty 模板 下 载 页 面 


图 关键 技术 


Smarty 模块 的 安装 步骤 : 
(1) 将 下 载 的 Smarty 压缩 包 解压 ， 解 压 后 的 文件 夹 如 图 14.2 所 示 ， 其 中 有 一 个 libs 文件 来， 包含 了 4 个 


Smarty 类 库 的 核心 文件 smarty.class.php、smarty_Compiler.class.php、config File.class.php 和 debug.tpl， 以 及 
internals 和 plug-ins 两 个 文件 夹 ， 如 图 14.3 所 示 。 
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图 14.6 第 一 个 Smarty 程序 


(3) 创建 配置 文件 。 如 果 要 应 用 Smarty 模板 ， 那 么 就 一 定 要 包含 Smarty 类 库 和 相关 信息 。 配 置信 息 可 以 


存储 在 一 个 单独 的 文件 中 ， 在 需要 时 通过 include 语句 包含 即 可 。 配 置 文件 config.php 的 代码 如 下 : 
<?php 

人 # ”定义 服务 器 的 绝对 路 径 */ 

define('BASE_PATH',$_ SERVER[DOCUMENT ROOTJ): 

人 # 定义 Smarty 模板 的 绝对 路 径 */ 

define('SMARTY_PATH,\mi\14\Smarty\"); 

族 ”加载 Smarty 类 库 文件 */ 

require BASE_ PATH .SMARTY PATHSmarty.class.php': 

人 # 实例 化 一 个 Smarty 对 象 %y 

S$smarty = new Smarty; 
”定义 各 个 目录 的 路 径 。 */ 


$smarty->template_dir ="./"; /定义 模板 文件 的 存储 位 置 
Ssmarty->compile_dir = '/Smarty/templates_c/ /定义 编译 文件 的 存储 位 置 
$smarty->config_dir ="/Smarty/configs/"; /定义 配置 文件 的 存储 位 置 
S$smarty->cache_dir= '/Smarty/cache/: /定义 缓存 文件 的 存储 位 置 
> 
上 述 配置 文件 的 参数 说 明 如 下 : 


BASE PATH: 指定 服务 器 的 绝对 路 径 。 

SMARTY PATH: 指定 Smarty 模板 的 绝对 路 径 。 

require0: 加 载 Smarty 类 库 文件 Smarty.class php。 

$smarty: 实例 化 Smart 对 象 。 

$smarty->template_dir: 定义 模板 文件 存储 位 置 。 

$smarty-> compile_dir: 定义 编译 文件 存储 位 置 。 

$smarty-> config_dir 定义 配置 文件 存储 位 置 。 

$smarty-> cache_dir: 定义 缓存 文件 存储 位 置 。 
图 设计 过 程 

完成 Smarty 模板 的 配置 后 ， 编 写 一 个 实例 ， 体 会 Smarty 模板 引擎 的 特性 。 

(1) 在 实例 558 文件 夹 下 创建 index.php 文件 ， 编 写 动态 PHP 代码 。 首 先 ， 设 置 页 面 的 编码 格式 。 然 后 ， 

通过 include 语句 包含 Smarty 的 配置 文件 。 最 后 , 通过 Smarty 类 库 中 的 assign0 方 法 将 数据 赋 给 模板 变量 ， 并 且 
应 用 display 指定 模板 页 ， 其 代码 如 下 : 

Fe "Content-type: text/html; charset=UTF-8" ); // 设 置 页 面 编码 格式 

include("config.php"); /包含 配置 文件 


全 ”使 用 Smarty 赋值 方法 将 一 对 儿 名 称 /方法 发 送 到 模板 中 。*/ 
$smarty->assign('title', 第 一 个 Smarty 程序 7: 


第 14 章 Smarty 模板 
S$str = file_get_contents('files/content.txt): /1/ 读 取 文 本 文件 中 的 数据 


S$smarty->assign('contenticonv("gb2312","utf-8",$str)): /将 文本 文件 中 的 数据 存储 到 模板 变量 中 
人 # 显示 模板 */ 
2 >display(index html; 


回 assign() 方 Ae ea 语法 如 下 : 


{assign var=" " value=" " 
参数 吨 被 研 什 的 变量 名 ， 参数 value 是 赋 给 变量 的 值 。 
用 午时 看 棋 枢 ; 需要 指定 一 个 合法 的 模板 资源 的 类 型 和 路 径 ， 还 可 以 通过 第 2 个 可 选 参 
数 指定 一 个 缓存 号 ， 相 关 的 信息 可 以 查看 缓存 。 
Void display (string template [, ER id [. string compile id]]) 
参数 template 指定 一 个 合法 的 模板 资源 的 类 型 和 路 径 ， 参 数 cache id 为 可 选 参数 ， 指 定 一 个 缓存 号 ; 参数 
compile id 为 可 选 参数 ， 指 定编 译 号 。 编 译 号 可 以 将 一 个 模板 编译 成 不 同 版 本 使 用 ， 例 如 针对 不 同 的 语言 编译 
模板 。 编 译 号 的 另外 一 个 作用 是 ， 如 果 存在 多 个 Stemplate_dir 模 板 目录 ， 但 只 有 一 个 $compile dir 编译 后 存档 目 
录 ， 这 时 可 以 为 每 一 个 Stemplate dir 模板 目录 指定 一 个 编译 号 ， 以 避免 相同 的 模板 文件 在 编译 后 互相 获 盖 。 相 
对 于 在 每 一 次 调用 display0 的 时 候 都 指定 编译 号 ， 也 可 以 通过 设置 $compile_id 编译 号 属性 来 一 次 性 设 定 。 
(2) 在 实例 558 文件 夹 下 创建 Smarty 文件 夹 ， 并 在 该 文件 夹 下 新 建 3 个 文件 夹 : templates c、configs 和 
cache。 
(3) 在 实例 558 文件 夹 下 创建 index.html 文件 ， 作 为 Smarty 的 模板 文件 ， 在 该 文件 中 输出 模板 变量 传递 
的 数据 ， 其 关键 代码 如 下 
<!-- 输 出 标题 
i 
<!-- 输 出 内 容 --> 
<p>{$content}</p> 
至 此 ， 第 一 个 应 用 Smarty 模板 开发 的 实例 编写 完成 ， 在 设计 过 程 中 只 讲解 了 3 个 步骤 ， 其 实 编写 一 个 完整 
的 Smarty 模板 实例 需要 5 个 步骤 : 
(1) 下 载 Smarty 类 库 文 件 ， 并 存储 到 指定 位 置 。 
(2) 编程 Smarty 模板 的 配置 文件 。 
(3) 创建 templates、templates c、configs 和 cache 文件 夹 ， 设 置 Smarty 中 各 种 文件 的 存储 位 置 。 
(4) 创建 动态 PHP 文件 ， 编 写 PHP 代码 。 
(5) 编写 Smarty 模板 文件 ， 设 计 静 态 页 面 ， 并 且 输 出 Smarty 模板 变量 中 传递 的 数据 。 
之 所 以 在 设计 过 程 中 给 出 3 个 步骤 ， 是 因为 其 他 两 个 步骤 已 经 在 关键 技术 中 进行 了 详细 的 讲解 。 
这 是 一 个 简单 的 Smarty 模板 应 用 实例 ， 读 者 也 许 体会 不 到 Smarty 模板 引擎 的 强大 功能 及 给 程序 开发 带 来 
的 便利 ， 但 是 通过 这 个 实例 已 经 展示 出 Smarty 应 用 的 基本 原理 和 操作 流程 。 
国 秘 稚 心 法 
心 法 领悟 558: Smarty 模板 引擎 的 特性 。 
Smarty 是 一 个 使 用 PHP 编写 的 应 用 于 PHP 的 模板 引擎 ， 它 将 一 个 应 用 程序 分 成 两 部 分 : 视图 和 逻辑 控制 。 
简单 地 讲 ， 就 是 将 UI (用 户 界面 ) 和 PHP code (PHP 代码 ) 分 离 。 这 样 ， 程 序 员 在 修改 程序 时 ， 不 会 影响 到 页 
面 设计 ， 而 美工 在 重新 设计 或 修改 页 面 时 ， 也 不 会 影响 程序 逻辑 。 


图 实例 说 明 
在 实例 558 中 讲解 的 Smarty 模板 配置 方法 有 一 个 弊端 ， 即 如 果 存储 实例 的 文件 夹 发 生变 化 ， 那 么 就 必须 修 
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改 config.php 配置 文件 中 常量 SMARTY PATH 的 值 ， 否 则 将 找 不 到 Smarty 类 库 的 存储 位 置 。 例 如 ,将 mr 文件 
夹 修改 成 mrs 文件 来， 那么 在 运行 实例 558 时 ， 将 输出 如 图 14.7 所 示 的 错误 信息 。 


mor | 
Ee | 多 
ERFTTEECTEITTET 眉目 5! ”| 


Warning requirc(E. tad Sww sl Smarty Smarty classphp) 
[fnction requre]:- faied No such fle or directory in 
E: NT or i php on line 7 


Fatal error require0 [fincioa reauie] Faied openingrequired 
到 /AppServ/ vrs Lh Sat Smarty .class Php” nclode path= ;C:php5 
pear) in E:AppServiwwwINRU4S58iconfigphp on ine 7 


xlkl 


EE TO 
图 14.7 ” 找 不 到 指定 的 Smarty 类 库 文件 
本 实例 向 读者 介绍 另外 一 种 Smarty 模板 的 配置 方法 ， 使 用 这 种 方法 ,无论 怎 么 改变 实例 的 文件 夹 ， 都 不 会 
影响 实例 的 运行 。 
图 关键 技术 


这 里 将 Smarty 配置 方法 封装 到 类 中 ， 并 存储 到 system.smarty.inc.php 文件 中 。 首 先 ， 包 含 Smarty 类 文件 
Smarty.class.php。 然 后 ， 定 义 SmartyProject 类 , 继承 Smarty 父 类 。 最后， 定义 SmartyProject0 方 法 , 设置 Smarty 
中 模板 文件 〈templates) 、 编 译文 件 〈templates c) 、 配 置 文件 (configs) 和 缓存 文件 〈cache) 的 存储 位 置 。 
这 就 是 新 的 配置 文件 system.smarty.incphp， 其 代码 如 下 : 


<?php 

require("../Smarty/Smarty.class.php"); /调用 Smarty 文件 

class SmartyProject extends Smarty{ /定义 类 ， 继 承 Smarty 父 类 

function SmartyProjectO{ // 定 义 方法 ， 配 置 Smarty 模板 
Sthis->template_dir ="./"; /指定 模板 文件 存储 在 根 目录 下 


/指定 编译 文件 存储 位 置 


Se 全 7 


既然 已 经 将 Smarty 的 配置 方法 存储 到 一 个 类 中 ， 那 么 就 需要 对 类 进行 实例 化 ， 根 据 返 回 的 对 象 名 称 调用 
Snare 中 的 方法 ， 类 的 实例 化 操作 在 system.inc.php 文件 中 完成 ， 其 返回 对 和 象 名 为 $smarty， 其 代码 如 下 : 


ee /调用 类 文件 
Ssmarty=new SmartyProject|; /执行 类 的 实例 化 操作 
> 


通过 此 方法 配置 Smarty 模板 的 好 处 是 ， 无 论 将 程序 复制 到 哪个 服务 器 下 执行 ， 都 不 需要 更 改 服务 器 或 者 
Smarty 文件 的 绝对 路 径 ， 程 序 可 以 直接 运行 。 


LEBg 技巧 : 这 种 配置 方法 中 调用 的 仍 是 存储 在 章 文件 来 14 下 的 Smarty 类 库 ， 同 时 在 这 种 方法 中 将 配置 文件 存 
储 于 实例 根 目 录 下 的 system 文件 夹 中 ， 将 模板 文件 夹 ( templates ) 、 编 译文 件 夹 ( templates c) 、 
配置 文件 夹 ( configs ) 和 缓存 文件 夹 ( cache ) 存储 在 system\Smarty 目录 下 。 


图 设计 过 程 


下 面 应 用 新 的 配置 方法 对 实例 558 进行 重新 编写 ， 生 成 实例 559， 步 又 如 下 : 
(1) 在 实例 的 根 目录 下 创建 system 文件 夹 , 存储 Smarty 的 配置 文件 system.smarty.inc.php 和 实例 化 操作 文 
件 system.incphp, 同时 创建 Smarty 文件 夹 ,最 后 在 Smarty 文件 夹 下 创建 3 个 文件 夹 templates_c、configs 和 cache。 
(2) 编写 index.php 文件 ， 重 新 载 入 Smarty 的 配置 文件 ， 即 通过 include 语句 包含 system.inc.php。 
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(3) 其 他 内 容 与 实例 558 相同 ， 这 里 不 再 殉 述 。 
为 了 让 读者 更 好 地 理解 Smarty 模板 的 配置 方法 和 文件 的 存储 位 置 ,下面 给 出 本 实例 的 文件 夹 架构 ,如 图 14.8 
所 示 。 


支 本 文件 存储 文件 去 


图片 文件 去 
Smarty 配 秆 文 件 去 


日 件 : 
7TT4 TT4HE9C9Wyindex htal. php 一 生成 的 编译 文件 

国 systee ine pip 一 一 一 一 一 一 一 一 一 实例 化 援 作文 件 

入 yt merty inc php 一 一 一 一 一 一 一 对 车 的 配 王 类 文件 


Smarty 类 应 文件 夹 


图 14.8 实例 559 的 文件 夹 架 构 


秘笈 心 法 
心 法 领悟 559: 确立 Smarty 类 库 文 件 的 存储 位 置 。 
在 本 章 中 , 我 们 将 Smarty 类 库 文件 存储 在 章 文 件 夹 14 下 , 本 章 中 所 有 的 实例 调用 的 都 是 这 个 Smarty 类 库 ， 
并 且 从 本 实例 开始 ， 以 后 的 实例 都 采用 本 实例 中 的 Smarty 配置 方法 ， 以 后 不 再 歼 述 。 
另外 ， 如 果 要 运行 本 章 中 的 某 个 实例 实例 558 除外 ) ， 必 须 将 Smarty 类 库 与 实例 文件 夹 放 置 于 同 级 目录 
下 ， 并 且 设 置 Smarty 类 库 的 名 称 为 Smarty。 


14.2 输出 数据 


前 用 户 的 权限 高 级 | 
趣味 指数 : ff 
图 实例 说 明 


在 动态 PHP 文件 中 , 可 以 通过 SESSION 变量 的 值 判断 当前 用 户 是 否 具有 访问 权限 , 而 在 Smarty 模板 页 中 ， 
不 可 以 使 用 SESSION 变量 , 那么 该 如 何 判断 用 户 是 否 具 有 访问 权限 呢 ? 这 就 是 本 实例 将 要 讲解 的 内 容 ,， 即 应 用 
让 语句 在 Smarty 模板 页 中 判断 用 户 是 否 具有 访问 权限 ， 其 运行 和 14.9 所 示 。 


实例 56 


图 14.9 站 语句 判断 用 户 是 否 具有 访问 权限 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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实例 561 


趣味 指数 : 二 便便 页 | 


图 实例 说 明 


本 实例 应 用 Smarty 模板 中 的 foreach 语句 在 模板 页 中 直接 生成 一 个 数字 验证 码 ， 它 相当 于 在 动态 PHP 中 开 
发 的 验证 码 ， 但 更 加 简单 、 实 用 。Smarty 模板 中 生成 验证 码 的 运行 结果 如 图 14.10 所 示 。 


国 让 后 位 各 管理 梧 录 


REN LI ZIYUAN GUAN LI XI TONG 


力 关键 技术 


严格 地 说 ， 这 个 验证 码 不 是 在 Smarty 模板 页 中 生成 的 ， 只 是 通过 foreach 语句 将 PHP 动态 页 中 生成 的 验证 
码 在 模板 页 中 输出 。 因 此 本 实例 开发 的 关键 是 foreach0 语 句 的 应 用 和 验证 码 的 生成 。 
(1) 应 用 mt_rand0 函 数 生成 验证 码 ， 其 语法 如 下 : 
int mt_rand ( [int min int max]) 
如 果 mt_rand0 函 数 没有 提供 可 选 参 数 min 和 max， 则 返回 0-RAND_MAX 之 间 的 伪 随 机 数 。 
(2) 应 用 explode0 函 数 将 生成 的 验证 码 写 入 到 数组 中 ， 其 语法 如 下 : 
array explode(string separator. string string. [int limit]) 
返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子 串 ,它们 被 字符 串 separator 作为 边界 点 分 隔 出 来 。 
如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 ; 
如 果 separator 为 空 字符 串 〈"") ，explode0 函 数 将 返回 FALSE; 如 果 separator 所 包含 的 值 在 string 中 找 不 
到 ， 那 么 explode0 函 数 将 返回 包含 string 单个 元 素 的 数组 ， 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 
元 素 外 的 所 有 元 素 。 
(3) 通过 assign0 方 法 将 验证 码 数组 赋 给 模板 变量 。 
(4) 应 用 foreach 语句 循环 输出 模板 变量 中 的 数组 元 素 。foreach 的 语法 如 下 : 
{foreach name=foreach_name key=key item=item from=arr_name} 
{foreach} 
参数 name 为 该 循环 的 名 称 ; key 为 当前 元 素 的 键 值 ， item 是 当前 元 素 的 变量 名 ; from 是 该 循环 的 数组 。 其 
中 ，item 和 from 是 必 选 参数 ， 不 可 省 略 。 


设计 过 程 
(1) 创建 system 文件 来， 封装 Smarty 模板 的 配置 方法 ， 这 里 不 再 熬 述 。 
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(2) 创建 index.php 文件 ， 生 成 验证 码 ， 并 且 将 验证 码 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 


php 

Tequire_once("system/system.inc.php"): /包含 配置 文件 

S$array= explode(… mt_rand(1000.9999)): // 生 成 随机 验证 码 
Ssmarty->assign('title'"'Smarty 模板 中 生成 数字 验证 码 ?: // 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', $array); // 将 数组 赋 给 模板 变量 
Ssmarty->display(index html: /指定 模板 页 

> 


(3) 创建 index.html 模板 文件 ， 设 计 用 户 登 录 页 面 ， 添 加 用 户 登 录 的 表单 元 素 ， 同 时 应 用 foreach 语句 输 
出 模板 变量 中 传递 的 验证 码 ， 其 关键 代码 如 下 : 
<form id="form1" name="forml" method="post" action="index_ok php"> 
<input name="user" type="text" id="user" size="10" /> 
<input type="hidden" name="checks" value™=" {foreach key=key itemritem fron-S$content) {Sitem} {/foreach}" /> 


type="password" i 
<input type="image" name="imageField" src="images/Blog 03 03.jpg" 户 
<input type="image" name="imageField2" onclick="form.reset(:retum false:" src="images/Blog_03_06.jpg" /> 
</form> 
(4) 创建 index_ok.php 文件 ,获取 表单 中 提交 的 数据 ， 对 用 户 登 录 信 息 进 行 验证 。 如 果 用 户 名 和 密码 正确 ， 
则 跳 转 到 main.php 页 面 ， 和 否则 跳 转 到 index.php 页 面 。 
(5) 创建 main.php 和 main .html 文件 ， 作 为 网 站 的 主页 。 


力 秘笈 心 法 
心 法 领悟 561: 验证 码 的 运用 。 


本 实例 中 ， 应 用 foreach 语句 输出 验证 码 ， 如 果 要 更 新 验证 码 的 值 ， 可 以 单 击 “ 刷 新 ”按钮 或 者 按 F5 键 ， 
同样 也 可 以 在 地 址 栏 中 重新 输入 地 址 。 


趣味 指数 : 窗 食 从 而 


图 实例 说 明 


在 Smarty 模板 页 中 ， 同 样 可 以 将 网 页 的 头 、 尾 和 主 文件 分 别 进行 存储 ， 从 而 达到 页 面 重 用 的 效果 ， 这 就 是 
本 实例 将 要 讲解 的 内 容 一 一 在 Smarty 模板 页 中 设计 网 页 页 面 ， 其 运行 结果 如 图 14.11 所 示 。 


FANXING ms erm ee J am 
,ELET EE LE [LS 胡乱 图 片 立 件 冯 
[a 看 奈 加 HE 冲击 SS Es 
口 。 标 晤 位 轨 坎 时 处 an ao0 
而 名 并 东方 式 
口 。 较 题 位 置 下 秋 外 nan 5330 54 Tar 开 
口 。 标题 位 置 放 云 外 il 3330 = 
现 条 电子 图 蔬 
口 。 棋 轴 位 轩 到 轩 处 nn 3310 us be 
口 。 标 原 位 轩 效 轩 处 110 a320 = 
口 。 棋 轴 们 置 轩 处 nn 330 
口 。 标题 位 团 族 轩 处 aaa 1 
口 。 株 归 位 置 下 过 外 ino 3320 
基 有 2 页 ， 当 说 是 莫 ! 页 Em) FF) 


图 14.11 Smarty 模板 中 的 页 面 设计 
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图 关键 技术 


在 Smarty 模板 页 中 应 用 include 函数 载 入 模板 页 。include 函数 用 于 在 当前 模板 中 包含 其 他 模板 ， 当 前 模板 
中 的 变革 在 被 包 合 的 模板 中 可 用 。include 函数 的 语法 如 下 ， 
{include file="file_name " assign—" " 
参数 file 指定 包含 机 权 六 件 的 名 称 , 为 必 选 参数 ;参数 assign 指定 一 个 变量 保存 包含 模板 的 输出 ;参数 var 
传递 待 包含 模板 的 本 地 参数 ， 只 在 待 包 含 模板 中 有 效 。 
图 设计 过 程 
(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 袭 述 。 
(2) 创建 index.php 文件 ， 应 用 switch 语句 根据 超 链接 传递 的 变量 值 ， 包 含 不 同 的 PHP 脚本 文件 ， 同 时 将 
对 应 的 模板 页 名 称 赋 给 指定 的 模板 变量 ， 其 代码 如 下 : 
ee /1/ 载 入 配置 文件 
switch ($_GET[caption]){ /应 用 switch 语句 ， 进 行 判断 
By i "reg.php"; // 包 含 PHP 脚本 
S$smarty->assign(admin phtml'vreg html):; /通过 模板 变量 指定 模板 页 


case "log"; 
include "log.php"; 
$smarty->assign('admin_phtml',log.html’): 
break; 
case "from"; 
include "for.php"; 
$smarty->assign('admin_phtml','for.html’); 
break; 
Case "mes"; 
include "mes.php"; 
$smarty->assign(admin phtml,mes.html): 
break: 
default: 
include "for.php"; 
S$smarty->assign('admin_phtml','for.html"): 
} 


Ssmarty->assign("title","Smarty 模板 中 的 页 面 设计 --".$_GET[caption]); 
>display("index.html"); /指定 模板 页 


(3) 创建 ndex.html 模板 页 ， 应 用 include 函数 载 入 页 面 的 头 文件 (top.html) 、 尾 文件 (bottom.html) 和 
主 文件 ， 其 关键 代码 如 下 : 
{Stitle} 
{include file=top html} 
{include file=Sadmin phtml} 
{include file=right html} 
{include file=bottom html} 


(4) 创建 include 函数 加 载 的 模板 文件 和 动态 PHP 文件 。 
图 秘笈 心 法 


心 法 领悟 562: switch 语句 的 应 用 。 

在 程序 设计 中 ， 所 有 依据 条 件 做 出 判定 的 问题 ， 都 可 以 用 站 条 件 语句 来 解决 。 不 过 ， 在 用 让..else 语句 处 理 
多 个 条 件 的 判定 问题 时 ， 组 成 条 件 的 表达 式 在 每 一 个 elseif 中 都 要 计算 一 次 ， 比 较 繁琐 。 为 了 避免 让 语句 的 宛 
长 ， 提 高 程序 的 可 读 性 ， 可 以 使 用 switch 分 支 控制 语句 。switch 语句 的 语法 如 下 : 

SS 


statementl: 
break: 
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case value2: 


default: 
default statement n: 
} 


switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比较 ， 如 果 不 相等 ， 继 续 查 找 下 一 个 case; 如 果 
相等 , 就 执行 对 应 的 语句 ,直到 switch 语句 结束 或 遇 到 break 为 止 . 一 般 switch 语 名 的 最 后 都 有 -个 默认 值 default， 
如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 ， 和 else 语句 类 似 。 


| 
高 级 | 
: 
| 


实 们 
实例 563 PE COR 


力 实例 说 明 


由 于 在 Smarty 模板 中 默认 使 用 “{” 和 “}” 作 


ET 


//102. 168. 1 59/er/14/007/ ~ Niereseft Tetersee e272 


为 定 界 符 ， 所 以 如 果 直 接 在 Smarty 模板 中 定义 CSS i ER LL i 
样式 ， 将 输出 如 图 14.12 所 示 的 错误 。 E 


Fatal error: Smarty emror [in index html ine §]: syntax error 
; (SI 


该 错误 出 现 的 原因 是 在 Smarty 模板 页 中 直接 将 。 | woet oe ios Dp oy cobreeepn 29 
Css 样式 中 使 用 的 “{” 和 “}” 解 析 为 Smarty 模板 ”局 mY 
的 定 界 符 ， 为 了 避免 在 Smarty 模板 中 直接 定义 CSS | i 、 
样式 时 出 现 错误 ，Smarty 提供 了 特殊 的 处 理 方法 ， 图 14.12 在 Smary 模板 中 直接 定义 CSS 样式 时 出 现 的 错误 
这 就 是 本 实例 将 要 讲解 的 literal 标签 。 
图 关键 技术 

literal 标签 ， 将 区 域内 的 数据 当 作文 本 处 理 ， 此 时 模板 将 忽略 其 内 部 的 所 有 字符 信息 。 该 特性 用 于 显示 有 
可 能 包含 大 括号 等 字符 信息 的 CSS 样式 或 者 JavaScript 脚本 ， 当 这 些 信息 处 于 {literal} {/literal} 标签 中 时 ， 模 
板 引擎 将 不 进行 分 析 ， 而 直接 显示 。 


图 设计 过 程 
这 里 仍然 应 用 实例 561 中 的 内 容 ， 唯 一 的 区 别 是 在 index.html 模板 页 中 ， 通 过 {literal} {/literal} 标签 定义 一 
个 CSS 样式 ， 控 制 页 面 中 表格 、 文 字 的 背景 、 字 体 和 大 小 等 ， 其 关键 代码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 设计 过 程 

这 里 仍然 应 用 实例 561 中 的 内 容 , 唯一 的 区 别 是 在 index.html 模板 页 中 , 直接 定义 JavaScript 脚本 对 表单 中 
提交 的 数据 进行 判断 ， 通 过 ldelin 和 rdelim 标签 在 Smarty 模板 中 输出 “{” 和 “}”， 其 关键 代码 如 下 : 

<script language=javascript> 

function check formO {ldelim} 

if (form.user.value 一 "fldelim} 


{rdelim} 
alert( 请 输入 密码 ”); 


本 实例 中 的 其 他 内 容 这 里 不 再 次 述 ， 其 完整 代码 请 参考 本 书 光盘 。 
图 秘笈 心 法 

心 法 领悟 564: literal 标签 与 Idelim、rdelim 标签 的 比较 。 

literal 标签 将 “{” 与 “} ”之 间 的 内 容 按 普通 的 文本 文件 来 解析 ， 控 制 的 是 内 容 ; 而 delim 与 rdelim 标签 在 
Smarty 模板 中 输出 “{” 与 “}”， 是 对 大 括号 本 身 进行 操作 。 在 Smarty 模板 中 完成 CSS 样式 或 者 JavaScript 脚 
本 的 嵌入 操作 时 ， 笔 者 个 人 认为 还 是 使 用 literal 标签 方便 一 些 。 


图 实例 说 明 
在 开发 程序 的 过 程 中 ， 经 常用 到 下 拉 列 表 框 ， 可 以 直接 用 户 注册 


在 页 面 中 为 其 定义 值 ， 也 可 以 使 用 从 数据 库 中 读 取 的 数据 来 
定义 ， 但 无 论 使 用 哪 种 方法 都 必须 应 用 option 标签 ， 这 是 在 


常规 的 Web 页 面 中 为 下 拉 列 表 赋值 的 方法 。 
本 实例 将 介绍 通过 Smarty 模板 中 的 自 定义 函数 html_ 0 
options 为 下 拉 列 表 框 赋值 。 使 用 Smarty 模板 中 的 自 定义 函数 


为 下 拉 列 表 框 赋值 与 使 用 option 标签 实现 的 效果 是 相同 的 ， 


' 
1 
' 
1 
' 
' 
» EMAL : Imrsof@mrsoft com 
' 
' 
' 
' 
1 
1 
1 


不 过 这 种 方法 更 加 适合 从 数据 库 中 读 取 数据 ， 更 符合 Smarty Ne 

开发 模式 动静 分 离 的 原则 ， 运 行 结果 如 图 14.14 所 示 。 
关键 技术 NS SH ] 
自 定义 函数 html_options 根据 给 定 的 数据 创建 选项 组 .该 二 本 


函数 可 以 指定 哪些 元 素 被 选 定 ， 要 么 指定 values 和 ouput 属 


es 
性 ， 要 么 指定 options 替代 。 自 定义 函数 的 语法 如 下 : 国 盾 生肖 过 二 下 人 人 全 国 且 入 下 失 列 二 芝 但 


780 


第 14 章 Smarty 模板 


<select name=customer id> 
{html_options values=$cust_ids selected-Scustomer id output-Scust_names} 
‘</select> 


html_options 函数 的 参数 说 明 如 表 14.1 所 示 。 


表 14.1 html_options 函数 的 参数 说 明 


参 数 类 型 

name string 下 拉 菜 单 名 称 ， 默 认 值 为 空 
options associative array 包含 值 和 显示 的 关联 数组 

selected string/array 已 选 定 的 元 素 或 元 素数 组 

output array 包含 下 拉 列 表 各 元 素 显示 值 的 数组 


Values arra. 包含 下 拉 列 表 各 元 素 值 的 数组 


如 果 给 定 值 是 数组 ， 将 作为 OPTGROUP 处 理 ， 且 支持 递归 。 所 有 的 输出 与 XHTML 兼容 。 

如 果 指 定 可 选 属性 name， 该 选项 列表 将 被 置 于 <select name="groupname"></select> 标 签 中 ， 如 果 没 有 指定 ， 
只 产生 选项 列表 。 
图 设计 过 程 

(1) 创建 system 文件 夹 。 首 先 ， 定 义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 以 及 ADODB 
连接 和 操作 数据 库 的 方法 。 然 后 ， 定 义 system_.inc.php 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 
实例 化 ， 并 返回 连接 对 象 。 最 后 ， 创 建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 
目录 。 

(2) 创建 index.php 文件 。 首 先 ， 设 置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 ， 生 成 随机 验证 码 ， 并 且 将 
随机 验证 码 的 值 赋 给 模板 变量 。 接 着 ， 从 数据 库 中 读 取 数 据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模 
板 变 量 ， 作 为 下 拉 列 表 中 的 值 。 最 后 ， 指 定 模板 页 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("system/system.inc.php"); // 包 含 配 置 文 件 

$array= explode(' ', mt_rand(1000,9999)); // 生 成 随机 验证 码 
Ssmarty->assign('title','html_option 函数 向 下 拉 列 表 中 添加 列表 项 ); // 将 指定 数据 赋 给 模板 变量 
S$smarty->assign('content', Sarray); // 将 数组 赋 给 模板 变量 
Sres=$conn->execute("select + from tb_bccd "):; /| 执行 select 查询 语句 
Sarray=$res->GetArray(); // 返 回 查 询 结果 

Sarray id=array(); 


rs Si<Sres- eonnil: SID{ 


Sarray id[]-Sarrayfsilfid]: 
i $array_name[]=$array[$i][name]: 
S$smarty->assign('cust_id', $array_id): /设置 下 拉 列 表 的 值 
S$smarty->assign('cust_name’, $array_name); // 设 置 列表 的 显示 数据 
S$smarty->display('index.html’); /指定 模板 页 


> 

(3) 创建 index.html 模板 页 。 首先 , 创建 form 表单 , 添加 表单 元 素 , 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html_options 自 定 义 函 数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 。 然 后 ， 
应 用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 ， 对 用 户 提交 的 信息 进行 验证 ， 其 关键 代码 如 下 : 


<form id="form" name="form" method="post" action="index_ok.php" onsubmit—"retum check_form(; "> 
词典 选择 : <select name="customer" id="customer">{html_options output=$cust_name values=Scust_id }</select> 

验证 码 : <input type="hidden" id="checks" name="checks" value="{foreach key=key item-item from=$content} {Sitem} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key itemr=item from=$content} {$item} {/foreach} 

<input type="image" name="imageField3" sre="images/reg_07.jpg" /> 

<input type="image" name="imageField4" onclick="form reset():return false:" src="images/reg_09.jpg” /> 

</form> 
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(4) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 数据 添加 到 数据 表 中 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html: charset=UTF-8" ); // 设 置 文 件 编码 格式 
Tequire_once("system/systeni inc.php"): /包含 配置 文件 
if($_POST['user]!=""&&$_POST['pass']!=""&&:$ POST[checks]'=""){ J 潭 断 用 户 名 和 密码 是 否 为 空 


Ssql="insert into tb user(user.pass.dates.email.type)values(™.$ POSTJuserl"w"mds(S POSTJpassT.w"date("Y-md ww"S POSTTemaill."。 
"S$_POST[customer].")"; 


Sres=$admindb->ExecSQL($sql,$conn); /| 执行 insert 添加 语句 
ifsresf 

echo "<scripf>alert( 用 户 注册 成 功 ! ) window.location.href='main.php';</script>"; 
Jelse{ 


echo "<script>alert( 用 户 注册 失败 ! )); window .location href-index.php':</script>": 
. 
jelsef 
echo "<script>alert( 用 户 注册 信息 不 可 为 空 ! ); windowlocation href=index.php';</script>"; 
} 


> 
(5) 创建 mainphp 和 main.html 文件 ， 定 义 用 户 注册 成 功 后 跳 转 的 页 面 。 代 人 码 请 参考 本 书 光盘 。 


图 秘笈 心 法 来 自 ht ts.1/192168 1 59 的 到 而 癌 。 


心 法 领悟 565: 文件 编码 格式 设置 的 重要 性 。 

在 PHP 脚本 中 ， 如 果 没 有 对 文件 的 编码 格式 进行 设置 ， 那 么 在 
输出 JavaScript 脚本 时 ， 如果 输出 的 是 中 文字 符 串 ,那么 将 输出 乱码 ， 
如 图 14.15 所 示 。 图 14.15 在 JavaScript 脚本 中 输出 乱码 


所 以 在 PHP 中 通过 headerO 函 数 设置 页 面 的 编码 格式 还 是 十 分 必要 的 ， 其 基本 的 使 用 方法 如 下 : 
header ( "Content-type: text/html:; charset=UTF-8" ); // 设 置 文件 编码 格式 


期 、 时 间 选 择 器 高 级 | 
趣味 指数 : 人 


力 实例 说 明 


在 Smarty 模板 中 ， 提 供 自 定义 的 日 期 、 时 间 处 理 函数 ， 通 过 它们 可 以 得 到 不 同 格式 的 日 期 、 时 间 信息 。 在 
本 实例 中 ， 将 应 用 Smarty 模板 中 的 日 期 、 时 间 选 择 函 数 ， 设 计 一 个 日 期 、 时 间 选 择 器 ， 记 录用 户 登录 的 时 间 ， 
其 运行 结果 如 图 14.16 所 示 。 


ma:[6 习 让 本 陋习 


用 各 :mr 


量 
目 
3 
日 


图 14.16 Smarty 模板 中 的 日 期 、 时 间 选 择 器 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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连接 和 操作 数据 库 的 方法 。 然 后 ， 定 义 system.incphp 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 实 
例 化 ， 并 返回 连接 对 象 。 最后， 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 index.php 文件 。 首 先 ， 设 置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 ， 生 成 随机 验证 码 ， 并 且 将 
随机 验证 码 的 值 赋 给 模板 变量 。 最 后 ， 指 定 index.html 模板 页 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html: charset=UTF-8" ); // 设 置 文 件 编码 格式 
Tequire_once("systenysystem. inc.php"); /包含 配置 文件 

$array= explode(' ', mt_rand(1000,9999)): // 生 成 随机 验证 码 
$smarty->assign('title'"'Smarty 模板 制作 日 期 、 时 间 选 择 器 "); /1/ 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', $array); // 将 数组 赋 给 模板 变量 
Ssmarty->display(index.html’); /指定 模板 页 

?> 


(3) 创建 index html 模板 页 ， 设 计 用 户 登录 的 form 表单 。 其 中 ， 应 用 html_select_date 和 html_select time 
函数 生成 日 期 、 时 间 下 拉 列 表 框 ， 应 用 foreach 语句 输出 验证 码 ， 最 终 将 表单 中 的 数据 提交 到 index_ok.php 文件 
中 ， 完 成 用 户 登 录 的 操作 ， 其 关键 代码 如 下 : 

<form id="fonm" name="form" method="post" action="index_ok:php" onsubmit="retum check_form0: "> 

日 期 : {html_select_date} 
时 间 : {html_select_time use_24_hours=true} 
用 户 名 : <input name= "user" type="text" id= "user" size="20" /> 
密码 <input name="pass" type="password" id="pass" size="20" /> 
验证 码 ; <input type="hidden" id="checks" name="checks" value=" {foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=Scontent} {$item} {/foreach} 
<input type="image" name="imageField3" src="images/reg 07.jpg" /> 
<input type="image" name="imageField4" onclick= "form resetO:retum false:" src="images/reg_09.jpg" /> 
</form> 
(4) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 用 户 登录 信息 ， 定 义 查 询 语句 验证 用 户 提交 的 用 户 名 和 密 
码 是 否 正确 ， 如 果 正 确 ， 则 根据 日 期 、 时 间 选 择 器 中 提交 的 数据 ， 更 新 用 户 注册 信息 表 中 的 最 后 登录 时 间 ， 其 
代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("system/system.ine.php"); /包含 配置 文件 
这 $_POST[user]'=""&S&S POST[pass]'=""&c&S POST[checks]'=""){ 
$sql="select * from tb_user Where user=".$_POST['user]." and pass=".md5($ POST[pass])."": 
Sres=$admindb->ExecSQL($sql.$conn); /执行 select 查询 语句 
if(Sres){ 
Slogin_date=$_POST['Date Year]."-".$_POST[Date_ Month']."-".$_POST[Date Day]." 
".$_POST[ Time_Hour].":".$_POST[ Time_Minute].":".$_POST['Time_Second']: 
$sqls="update tb user set login date=".$login date." Where user=".$ POST[user]." and pass=".md5($ POSTTpass])."": 
Srs=$admindb->ExecSQL($sqls,Sconn); /执行 pdate 更 新 语句 
echo "<script>alert( 用 户 登录 成 功 ! )); window.location href='main.php';</script>"; 
Jelse{ 
echo "<script>alert( 用 户 登录 失败 ! "); window.location.href='index.php';</script>": 


else{ 

2 echo "<script>alert( 用 户 登录 信息 不 可 为 室 ! 9): window.location.href='index.php':</script>"; 

} 

> 

(5) 创建 main.php 和 main html 文件 ， 作 为 用 户 登录 成 功 的 跳 转 页 面 ， 其 代码 请 参考 本 书 光盘 。 
图 秘笈 心 法 


心 法 领悟 566: 如 何 获取 日 期 、 时 间 下 拉 列 表 框 中 的 值 。 

在 index.html 模板 页 中 直接 应 用 {html select_date} 和 {html select_time use 24_hours=true} 定 义 日 期 、 时 间 下 
拉 列 表 框 ， 那 么 应 该 如 何 获取 下 拉 列 表 框 中 对 应 的 值 呢 ? 方法 是 在 index.html 和 indexphp 编写 完成 后 ， 运 行 
index.php 文件 ， 查 看 其 源 文件 即 可 获取 日 期 、 时 间 下 拉 列 表 框 对 应 的 名 称 。 然 后 ， 就 可 以 在 表单 处 理 页 中 通过 
$_POST[] 方 法 获取 日 期 、 时 间 的 值 。 
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14.3 综合 应 用 


高 级 
趣味 指数 : | 


图 实例 说 明 


在 本 实例 中 , 综合 运用 前 面 讲解 的 方法 、 技 术 , 在 模板 页 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 ,通过 foreach 
语句 输出 验证 码 ， 通 过 html options 函数 定义 下 拉 列 表 框 的 值 ， 并 且 增 加 Ajax 技术 实现 用 户 名 的 无 刷新 验证 ， 
开发 一 个 完整 的 Smarty 用 户 注册 功能 模块 ， 其 运行 结果 如 图 14.17 所 示 。 


用 户 注册 


a: [1139 1 


图 14.17 Smarty 模板 中 的 用 户 注册 


力 关键 技术 


通过 Ajax 技术 实现 无 刷新 验证 整体 上 可 以 分 为 3 个 步骤 : 
第 1 步 : 在 模板 页 中 ， 通 过 script 标签 调用 指定 的 JS 文件 。 创 建 from 表单 ， 添 加 表单 元 素 ， 通 过 onBlur 
事件 调用 JavaScript 脚本 函数 ， 完 成 对 表单 元 素 值 的 判断 。 
第 2 步 : 编写 JavaScript 脚本 文件 ， 创 建 自 定义 函数 ， 应 用 Ajax 技术 完成 对 表单 元 素 值 的 验证 。 
第 3 步 : 在 模板 页 中 ， 通 过 div 标签 输出 验证 结果 。 
其 中 应 用 到 的 Ajax 技术 如 下 : 
(1) 在 使 用 XMLHttpRequest 对 象 发 送 请 求 和 处 理 响 应 之 前 , 首先 需要 初始 化 该 对 象 ,由 于 XMLHttpRequest 
不 是 一 个 W3C 标准 ， 所 以 对 于 不 同 的 浏览 器 ， 初 始 化 的 方法 也 是 不 同 的 。 
这 里 使 用 正 浏 览 器 把 XMLHttpRequest 实例 化 为 一 个 ActiveX 对 象 ， 具 体 方法 如 下 : 
var http_request = new ActiveXObject("Msxml2.XMLHTTP"): 
或 者 
Var http_request = new ActiveXObject("Microsoft. XMLHTTP"): 
在 上 面 的 语法 中 ，Msxml2.XMLHTTP 和 MicrosoftXMLHTTP 是 针对 正 浏览 器 的 不 同 版 本 而 进行 设置 的 。 
(2) open() 方 法 。 
open() 方 法 用 于 设置 进行 异步 请 求 目 标的 URL、 请 求 方法 以 及 其 他 参数 信息 ， 语 法 如 下 : 
open("method""URL"[LasyncFlag[."userName"[. "password"]]]) 
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在 上 面 的 语法 中 ，method 用 于 指定 请 求 的 类 型 ， 一 般 为 get 或 post;，URL 用 于 指定 请 求 地 址 ， 可 以 使 用 绝 


对 地 址 或 者 相对 地 址 , 并 且 可 以 传递 查询 字符 串 ; asyncFlag 为 可 选 参数 , 用 于 指定 请 求 方式 , 同步 请 求 为 TRUE， 
异步 请 求 为 FALSE, 默认 情况 下 为 TRUE; userName 为 可 选 参数 ,用 于 指定 请 求 用 户 名 , 没有 时 可 省 略 ; password 


为 可 选 参数 ， 用 于 指定 请 求 密码 ， 没 有 时 可 省 略 。 
(3) send( 方 法 。 
send( 方 法 用 于 向 服务 器 发 送 请 求 。 如 果 请 求 声明 为 异步 , 该 方法 将 立即 返回 


其 语法 如 下 : 
send(content) 
在 上 面 的 语法 中 ，content 用 于 指定 发 送 的 数据 ， 可 以 是 DOM 对 象 的 实例 、 
数 需 要 传递 ， 可 以 设置 为 null。 
(4) XMLHttpRequest 对 象 的 常用 属性 。 
XMLHttpRequest 对 象 的 常用 属性 如 表 14.4 所 示 。 


表 14.4 XMLHttpRequest 对 象 的 常用 属性 
属 性 说 阴 


， 否则 将 等 到 接收 到 响应 为 止 ， 


输入 流 或 字符 串 。 如 果 没 有 参 


onreadystatechange 每 个 状态 改变 时 都 会 触发 这 个 事件 处 理 器 ， 通 常会 调用 一 个 JavaScript 函数 


请 求 的 状态 ， 有 以 下 5 个 取 值 : 
0= 未 初始 化 

1= 正在 加 载 

2= 已 加 载 

3= 交互 申 

4= 完成 

responseText 服务 器 的 响应 ， 表 示 为 字符 串 


readyState 


responseXML 服务 器 的 响应 ， 表 示 为 XML。 这 个 对 象 可 以 解析 为 一 个 DOM 对 象 


返回 服务 器 的 HTTP 状态 码 ， 如 : 

200=" 成 功 " 

202=" 请 求 被 接受 ， 但 尚未 成 功 " 

400=" 错 误 的 请 求 " 

404=" 文 件 未 找到 " 

500=" 内 部 服务 器 错误 " 
statusText 返回 HTTP 状态 码 对 应 的 文本 


status 


(5) XMLHttpRequest 对 象 与 服务 器 交互 。 


XMLHttpRequest 对 象 的 最 大 用 途 就 是 不 需要 刷新 页 面 即 可 以 与 服务 器 进行 交互 。 可 以 将 Ajax 与 服务 器 的 


交互 分 为 以 下 3 个 步骤 : 
@ 初始 化 XMLHttpRequest 对 象 ， 关 键 代 码 如 下 : 
var xmlHttp = false; /定义 XMLHttpRequest 对 象 
ty{ // 如 果 浏 览 器 支持 XMLHttpRequest 对 象 ， 创 建 ActiveXObject 对 象 


xmlHttp = new ActiveXObject("Msxml2 XMLHTTP"); 
}catch (e) { 
ty{ 


xmlHttp = new ActiveXObject("Microsoft XMLHTTP"): 
} catch (e2) 全 


} 
if (!xmlHttp &é& typeof XMLHttpRequest != "undefined") { 
try{ 


xmlHttp = new XMLHttpRequestO: 
}catch(e3){ xmlHttp = false:} 
} 
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@ 设置 请 求 状 态 和 返回 处 理 函 数 ， 语 法 格式 如 下 : 

xmlobj.onreadystatechange-function_name: 

其 中 xmlobj 是 XMLHttpRequest 的 对 象 ，function_name 是 用 来 处 理 请 求 状 态 和 返回 码 的 函数 名 ( 即 回调 
函数 ) 。 

@@) 发 送 HITP 请 求 ， 语 法 格式 如 下 : 

xmlobj.open(send_method.url.flag); 

其 中 xmlobj 是 XMLHttpRequest 的 对 象 ，send_method 是 发 送 方法 ， 可 以 是 GET 或 者 POST， 与 表单 中 使 
用 的 方法 相对 应 ; url 是 页 面 要 调用 的 地 址 ，flag 是 一 个 标记 ， 如 果 为 TRUE 则 表示 在 等 待 被 调用 页 面 响应 的 时 
间 内 可 以 继续 执行 页 面 代码 ， 反 之 为 FALSE。 
图 设计 过 程 

(1) 定义 Smarty 的 配置 方法 和 ADODB 连接 、 操 作 数据 库 的 方法 ， 有 关内 容 请 参考 实例 565， 这 里 不 再 

(2) 创建 ndex.php 文件 。 首 先 ， 设 置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 ， 生 成 随机 验证 码 ， 并 且 将 
随机 验证 码 的 值 赋 给 模板 变量 。 接 着 ， 从 数据 库 中 读 取 数 据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模 
板 变量 ， 作 为 下 拉 列 表 中 的 值 。 最 后 ， 指 定 模板 页 。 

(3) 创建 mdex.html 横 板 页 。 首 先 , 创建 form 表单 , 添加 表单 元 素 , 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html_options 自 定义 函数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 。 然 后 ， 
应 用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 。 最 后 ， 通 过 script 标签 载 入 JavaScript 脚本 文件 ， 对 用 户 提交 的 注 
册 信息 进行 判断 ， 其 关键 代码 如 下 : 

{literal} 

<style type="text/css"> 

body,tdith { 

font-size: 12px; 

a 

{/literal} 

‘<script language="javascript" src="js/createxmlhttpjs"></script> 

‘<script language="javascript" src="js/check form.is"></script> 

<form id="form" name="form" method="post" action="index_ok.php" onsubmit="retum check_formO: "> 

用 户 名 : <input name="user' type="text" id="user" onBlur="javascript:chkname(" size="20" /> 

<div id="user_check"><font color="#999999"> 请 输入 用 户 名 </font></div> 

词典 选择 <select name="customer' id="customer"> {html_options output=S$cust_name values=Scust_id }</select> 
验证 码 :<input type="hidden" id="checks" name="checks" value=" {foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content} {$item} {/foreach} 
</form> 

(4) 创建 js 脚本 文件 夹 。 首 先 ， 编 写 createxmlhttpjs 文件 ， 完 成 Ajax 中 XMLHttpRequest 对 象 的 初始 化 
操作 。 然 后 ， 编 写 check formjjs 文件 ， 定 义 check_form0 方 法 对 表单 中 提交 的 数据 进行 验证 ， 定 义 chkname() 
方法 调用 chkname.php 文件 实现 用 户 名 的 无 刷新 验证 ， 定 义 checkregemail(emails) 方 法 验证 邮箱 地 址 的 格式 是 否 
正确 ; 定义 checkregtelregtel) 方 法 验证 电话 号 码 的 格式 是 否 正确 。 其 中 chkname0 方 法 的 语法 如 下 : 


function chknameOf 
if(document.getElementById('user’).value—""){ 1/ 判断 用 户 名 表单 元 素 值 是 否 为 空 
document.getElementById('user_check'").innerHTML="<font color=#FF0000> 请 输入 用 户 名 ! </font>"; /如果 为 室 则 输出 该 内 容 
jelsef 
var user = document getElementById(user) value: /否则 获取 用 户 名 
var url = "chkname.php?user="+user: /定义 ul 
xmlhttp.open("GET"urLtrue): /通过 GET 方法 执行 
xmlhttp.onreadystatechange = functionO{ // 回 调 函 数 
这 xmlhttp readyState — 4){ 1/ 判断 返 回 值 
var msg = xmlhttp.responseText: /获取 返回 值 
iftimsg —'1){ 1/ 判断 如 果 返 回 值 为 1 
document.getElementById('user_check’).innerHTML="<font color=#FF0000> 用 户 名 被 占用 ! </font>"; 7/ 则 说 明 用 户 名 被 占用 
Tetum false: 
}else if(msg —'0){ // 判 断 如 果 返 回 值 为 0 


document getElementById('user_check').innerHTMI="<font color-green> 恭 喜 您 ， 可 以 注册 !'</font>": 。“// 用 户 名 可 用 
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jelsef 
document.getElementById(user check) innerHTMIL="<font color=green>"+msg+"</font>"; /输出 可 用 用 户 名 
} 
} 


} 

xmilhttp.send(null); /执行 发 送 
} 
} 


(5) 创建 chkname.php 文件 , 根据 超 链接 中 传递 的 参数 值 判 断 提交 的 用 户 名 是 否 被 占用 , 如 果 用 户 名 可 用 ， 
则 定义 变量 $reback 的 值 为 0， 否则 定义 变量 $reback 的 值 为 1， 代 码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
Tequire_once("systeny/system.inc.php"); /包含 配置 文件 
$sqls="select name from tb name where name=".$ GETfmserl"": 
Sres=$admindb->ExecSQL($sqls,Sconn); // 执 行 select 查询 语句 
这 Sres){ 

Sreback ="1'; /用 户 名 被 占用 
jelsef 

Sreback = '0'; /用 户 名 可 用 
Sreback: 


“6) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 数据 存储 到 指定 的 数据 表 中 。 
(7) 创建 main.php 和 main.html 文件 ， 编 写 用 户 注册 成 功 后 跳 转 的 页 面 。 


图 秘笈 心 法 

心 法 领悟 567: Ajax 技术 中 XMLHttpRequest 对 象 的 readyState 属性 。 

在 正 浏 览 器 中 应 用 XMLHttpRequest 对 象 的 readyState 属性 ， 可 以 书写 为 readystate， 而 在 火狐 浏览 器 下 应 
用 XMLHttpRequest 对 象 的 readyState 属性 ， 必 须 书写 为 readyState。 所 以 为 了 保证 其 在 不 同 的 浏览 器 下 都 可 以 
使 用 ， 在 输出 时 统一 使 用 readyState。 
台 管理 系统 主页 高 级 


ES i 
实例 568 Male 人 


图 实例 说 明 


在 本 实例 中 ， 开 发 一 个 后 台 管 理 系统 ， 包 括 管理 员 的 登录 、 退 出 、 后 台 管 理 系统 中 各 个 模块 的 功能 展示 模 
块 ， 当 然 这 些 模块 都 只 是 简单 的 架构 ， 没 有 实现 具体 的 功能 eget ee 
过 Smary 模板 构建 后 台 管 理 系统 的 主页 ， 而 非 某 些 具体 功 旬 纶 模块 的 开发 。 本 实例 首先 展示 后 台 管 理 的 登录 模块 ， 
如 图 14.18 所 示 ， 登 录 成 功 后 将 进入 到 后 台 管 理 系 统 的 主页 ， 如 图 14.19 所 示 。 


明 目 购 入 至 局 局 ， 天 百丽 物 宝 局 二 二 
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oe IT em 
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Tr nn rs 
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oa 


图 14.18 后 台 登 录 图 14.19 ”后台 管理 主页 
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(5) 创建 热点 链接 中 链接 的 动态 PHP 文件 和 模板 文件 。 由 于 篇 幅 所 限 ， 这 里 不 对 这 部 分 内 容 进 行 详细 讲 
解 ， 读 者 可 以 参考 本 书 光盘 。 


图 秘笈 心 法 


心 法 领悟 568: Smarty 模板 中 的 URL 编码 。 
在 本 实例 中 ,通过 超 链接 传递 参数 值 时 ， 应 用 Smarty 模板 中 的 escape 方法 ， 对 超 链接 传递 的 参数 值 进行 编 
码 ， 进 而 保护 传递 数据 的 安全 。 


高 级 
趣味 指数 : 丛 食 寅 而 


图 实例 说 明 


在 PHP 动态 页 中 ， 可 以 通过 while、do...while、for 和 foreach 语句 实现 数据 的 循环 输出 ， 而 在 Smarty 中 ， 
也 有 属于 自己 的 循环 输出 语句 foreach 和 section。 在 本 实例 中 ， 将 介绍 通过 section 语句 完成 数据 的 循环 输出 ， 
其 运行 结果 如 图 14.20 所 示 。 


管理 只: 个 首页 登 退出 


当天 加 : 2010E08 同 14 日 


几 
四 商品 管理 


9 再 吉 大 加 


会 员外 理 => 合 员 浏 览 
卫 公 员 名 种 al | ta 


2010-00-09 
9 再 品 修 疯 


站 半 册 过 再 ee 


日 会 员 册 除 


2010-05-09 
| co 


© 会 员 浏 览 
图 14.20 Smarty 模板 下 载 页 面 


力 关键 技术 


section 循环 语句 ， 用 于 比较 复杂 的 数组 ， 其 语法 如 下 : 


{section name="sec_name” loop=$arr_name start=num step=num} 

参数 说 明 : 

name: 表示 循环 的 名 称 。 

loop: 表示 循环 的 数组 。 

start: 表示 循环 的 初始 位 置 ， 如 果 start=2， 那 么 说 明 循 环 从 loop 数组 的 第 2 个 元 素 开始 。 

step: 表示 步 长 ， 如 果 step=2， 那 么 循环 一 次 后 ， 数 组 的 指针 将 向 下 移动 两 位 ， 以 此 类 推 。 

Section 循环 语句 读 取 的 是 存储 在 模板 变量 中 的 数组 元 素 , 而 这 个 数组 元 素 值 是 在 动态 PHP 文件 中 通过 调用 
数据 库 操作 类 中 的 $admindb->ExecSQL 方法 获取 的 。 
究 其 根源 就 是 应 用 ADODB 类 库 中 的 GetRows0 方 法 获取 的 查询 结果 ， 有 关 其 具体 的 设置 可 以 参考 封装 的 
数据 库 操作 类 AdminDB， 该 类 存储 于 system\ system.smarty.inc.php 文件 中 。 


图 设计 过 程 
(1) 本 实例 以 实例 568 中 开发 的 后 台 管 理 系统 主页 为 基础 ， 首 先 去 除 后 台 管 理 系统 的 登录 功能 ， 直 接 在 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<td style="padding-bottom:5px; padding-left: 5px; padding-right:5px: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].user}</td> 
<td style="padding-bottom:5px; padding-left: 5px; padding-right:5px: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].email}</td> 
<td style="padding-bottom:5px: padding-left:5px: padding-right:Spx: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[idl.dates}</td> 
A> 
{/section} 


在 上 述 section 语句 中 ， 将 从 数组 的 第 2 个 元 素 开始 循环 ， 并 且 数 组 指针 一 次 向 下 移动 两 位 。 
注意 ， 在 应 用 section 语句 时 ， 一 定 要 有 {/section} 结 束 标记 。 


图 实例 说 明 
ele section 语句 循环 输出 数据 库 中 数据 的 基础 上 ， 增 加 一 个 分 页 功能 ， 实 现 对 数据 库 中 数据 的 分 


页 显示 ， 运 行 结果 如 图 14.21 所 示 。 


明日 购物 坚 向 局 忆 千 = 
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9 会员 出 院 


图 14.21 Smarty 模板 中 数据 的 分 页 输出 


图 关键 技术 


在 Smarty 中 实现 分 页 与 在 PHP 文件 中 实现 分 页 的 原理 是 相同 的 ， 唯 一 的 区 别 是 ， 在 Smarty 中 分 页 的 处 理 

操作 与 分 页 的 显示 是 分 离 的 。 分 页 的 处 理 操作 存储 在 sho_delete php 文件 中 ， 其 应 用 到 的 关键 技术 如 下 : 
(1) mysql_ query0 函 数 ， 执 行 查询 、 更 改 以 及 删除 等 操作 ， 语 法 如 下 : 

Tesource mysql_query ( string query [, resource link identifier] ) 

参数 query 为 字符 串 类 型 ， 指 定 传 入 的 SQL 指令 ;参数 link identfier 为 资源 类 型 ， 指 定 传 入 的 由 mysql_ 
connect() 函 数 或 mysql_pconnectO 函 数 返 回 的 连接 标识 。 如 果 省 略 该 参数 ， 则 会 使 用 最 后 一 个 打开 的 MySQL 数 
据 库 连接 。 

(2) mysql_fetch_arrayO 函 数 ， 从 数组 结果 集中 获取 数据 ， 语 法 如 下 : 


array mysql _fetch_array ( resource result [., int result_type] ) 

参数 说 明 : 

result: 资源 类 型 的 参数 ， 要 传 入 的 是 由 mysqlL_query0 函 数 返 回 的 数据 指针 。 

result_type: 可 选项 ， 整 数 型 参数 ， 要 传 入 的 是 MYSQL ASSOC、MYSQL NUM、MYSQL BOTH 3 种 由 
PHP 定义 的 常数 之 一 , 默认 值 是 MYSQL BOTH. MYSQL ASSOC 只 得 到 关联 索引 (相当 于 mysql fetch_assocO 
函数 ) ; MYSQL NUM 只 得 到 数字 索引 (相当 于 mysql_fetch row0 函 数 ) ; MYSQL BOTH 将 得 到 一 个 同时 包 
含 关联 和 数字 索引 的 数组 。 

(3) array0 函 数 ， 定 义 一 个 数组 ， 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 “=>” 运 算 符 给 出 索引 。array0 
函数 是 一 个 语言 结构 ， 用 于 字面 上 表示 数组 ， 不 是 常规 的 函数 ， 语 法 如 下 : 


anay anay([mixed 了 ) 
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参数 mixed 的 语法 为 key => value， 多 个 参数 间 用 去 号 分 开 ， 分 别 定义 了 索引 和 值 。 

索引 可 以 是 字符 串 或 数字 。 如 果 省 略 了 索引 ， 会 自动 产生 从 0 开始 的 整数 索引 。 3 则 下 一 
个 产生 的 索引 将 是 目前 最 大 的 整数 索引 +1。 如 果 定 义 了 两 个 完全 一 样 的 索引 ， 则 后 面 一 个 会 覆盖 前 一 个 。 
(4) amray_pushO 函 数 ， 将 数组 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 该 数组 的 末尾 ， 训 数 组 的 长 度 将 增加 入 术 
变量 的 数目 ， 返 回 数组 新 的 单元 总 数 。 语 法 如 下 : 

int array push ( array array, mixed var [, mixed ...]) 

参数 说 明 : 

array: 必 选 参数 ， 输 入 的 数组 。 

var: 必 选 参数 ， 用 来 压 入 数组 的 值 。 

var2: 可 选 参数 ， 用 来 压 入 数组 的 值 。 

(5) 通过 PHP 中 的 函数 、 方 法 将 从 数据 库 中 读 取 的 数据 进行 分 页 处 理 ， 通 过 $smarty 对 象 调用 assign() 方 
法 将 分 页 处 理 返 回 的 变量 传递 给 模板 变量 ， 并 通过 display0 方 法 指定 模板 页 。 

(6) 在 模板 页 sho_delete.html 中 ， 获 取 模板 变量 传递 的 值 ， 完 成 数据 的 分 页 输出 。 
图 设计 过 程 

本 实例 开发 后 台 管 理 系统 中 的 商品 删除 模块 ， 其 对 应 的 操作 文件 是 sho_delete.php 和 sho_delete.html。 要 执 
行商 品 的 删除 操作 ， 首 先 必 须 输出 数据 库 中 存储 的 商品 数据 ， 这 是 本 实例 的 重点 ， 再 在 Smarty 模板 中 实现 数据 
的 分 页 输出 。 

(1) 编辑 sho_delete.php 文件， 连接 数据 库 、 载 入 Smarty 配置 文件 ， 通 过 SQL 语句 读 取 数 据 库 中 的 数据 ， 
并 且 定 义 数据 的 分 页 输出 方法 ， 应 用 Smarty 中 的 assign0 方 法 将 分 页 输出 的 变量 值 传 递 给 模板 页 ， 最 终 指定 模 
板 页 ， 其 代码 如 下 : 


<?php 
include_once "conn/conn.php"; /连接 数据 库 
require_once("system/system.inc.php"); /调用 指定 的 配置 文件 
/执行 查询 语句 ， 从 数据 库 中 读 取 商 品 信息 
$sql=mysql query("select count(*) as totall from tb bccd ",$conn); 
Sinfo=mysql fetch_array($sql); 
Stotall=$info[totall]: /统计 数据 库 中 数据 总 数 
这 empty($_GET[pages]) 一 tmue | is_numeric($_GET[pages]) 一 flse){ // 浏 断 变量 pages 是 否 为 空 
S$pagel=1; /如 果 变 量 为 室 ， 则 赋值 为 1 
yelse{ /如果 不 为 室 ， 则 获取 变量 的 值 
Spagel=intval($ GET[pages]): 
} 
Spagesizel=3; /定义 每 页 显示 3 条 记录 
if($totall<$pagesizel){ /1/ 判 断 如 果 数 据 库 中 数据 小 于 每 页 显示 的 记录 数 
Spagecount1=1; /1/ 则 定义 pagecount 变量 的 值 为 1 
Yelsef 
if($totall%$pagesizel—0){ 
Spagecount1=intval(S$totall/Spagesizel); 1/ 用 总 的 记录 数 除 以 每 页 显示 的 记录 数 ， 获 取 共有 几 页 
jelsef 
Spagecountl=intval(Stotall/Spagesizel)+1: 
} 
! 
/将 要 输出 的 数据 赋 给 assign 模板 变量 
Ssmarty->assign("totall",Stotall); 
Ssmarty->assign("pagesizel".Spagesizel): 
S$smarty->assign("pagel".Spagel): 


$smarty->assign("pagecount1".$pagecountl): 
$query=mysql_query("select * from tb_bced order by id desc limit " (Spagel-1D)*Spagesizel.".Spagesizel".Sconn ): 
Smyrow=mysql fetch array($query): 


Sarray=array(); /定义 一 个 空 数组 
dof 
array_push($array.Smyrow): // 将 获取 的 数组 值 写 入 到 新 的 数组 中 
}while($myrow=mysql fetch_array($query)): /循环 读 取 数据 库 中 数据 
if(!Sarray){ 
S$smarty->assign("iscommo"."F"): /判断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
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Jelse{ 
Ssmarty->assign("iscommo"."T™"); 1/ 判断 如 果 执 行 成 功 ， 则 输出 模板 变量 的 值 为 
Ssmarty->assign("arr”", Sarray): /定义 模板 变量 arr， 输 出 数据 库 中 的 数据 


} 
Se "商品 删除 "); 


(2) 编辑 sho_delete.html 模板 页 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 ， 其 关键 代码 如 下 : 
<table width="545" border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#3399CC"> 
<t> 
<td height="25" align="center" bgcolor="#FFFFFF">ID</td> 
<td align="center" bgcolor="#FFFFFF"> 商 品名 称 </td> 
<td align="center" bgcolor="#FFFFFF"> 操 作 </td> 
<ft> 
{section name=id loop=$arr} 
<t> 
<td align="center" bgcolor="#FFFFFF">{$arlidl.id}</td> 
<td bgcolor="#FFFFFF">{$arfid].name}</td> 
<td align="center" bgcolor="#FFFFFF"><a href="delete.php?conn_id={$ar[id].id}"> 删 除 </a></td> 
<tr> 
{/section} 
</table> 
<table width="545" height="25" border="0" align="center”" cellpadding="0" cellspacing="0"> 
<t> 


<td> 图 书 &nbsp; {Stotall}&nbsp; 本 &nbsp; 每 页 {$pagesizel} 本 &nbsp; 第 &nbsp;{$pagel}&nbsp; 页 / 共 &nbsp;{$pagecount1}&nbsp: 页 </td> 
<td align="center">{if $pagel 一 1 } 首 页 &nbsp; 上 一 页 {else}<a href="index.php?caption={$titlelescape:"url"}&zpages=1"> 首 页 </a>&nbsp; 
<a href="index.php?caption={ $titlelescape:"url"} &pages={$pagel1-1}" > 上 一 页 </a>{/if} {if $pagel 一 $pagecountl } 下 一 页 &nbsp: 尾 页 {else} 
<a href="index.php?caption={ $titlelescape:"url"} &pages={$pagel+1}"> 下 一 页 </a>&nbsp; 
<a href="index.php?caption={ $titlelescape:"url"} &pages={$pagecount1}"> 尾 页 </a>{/if} 
</td> 
<ht> 
</table> 
(3) 商品 的 删除 通过 delete.php 文件 ， 以 超 链接 传递 的 参数 conn id 为 条 件 ， 执 行 delete 删除 语句 ， 其 代 
人 码 如 下 : 

<?php 
include_once "conn/conn php"; // 连 接 数 据 库 
require_once("system/system.inc.php"); 1/ 调 用 指定 的 文件 
$sql=mysql_query("delete from tb_bccd where id=".$_GET['conn id]."".Sconn): /执行 删除 语句 
if($sqD){ 

echo "<script>alert( 数 据 删 除 成 功 ! ");window.location.href='index.php':</script>"; 
jelsef 

echo "<script>alert( 数 据 删除 失败 ! ):window.location hre 人 index.php':</script>": 
} 


> 


力 秘笈 心 


心 法 领悟 570: 将 mysql_fetch_array0 函 数 返回 的 结果 在 Smarty 模板 中 输出 。 

mysql_fetch_array0 函 数 返回 的 结果 集 是 一 维 数组 ， 而 Smarty 模板 中 section 循环 语句 读 取 的 是 二 维 数 组 中 
的 数据 ， 所 以 要 将 mysql_fetch_array0 函 数 返 回 的 结果 集 在 模板 页 中 循环 输出 ， 必 须要 将 结果 集 添加 到 一 个 数组 
中 ， 然 后 才能 应 用 section 语句 ， 其 具体 的 方法 可 以 参考 本 实例 中 的 sho_delete.php 文件 。 


3 完成 数据 的 分 页 显示 


将 


实例 571 


图 实例 说 明 


本 实例 将 介绍 通过 面向 对 象 的 方法 完成 Smarty 的 配置 、ADODB 连接 和 操作 MySQL 数据 库 ， 以 及 分 页 的 
功能 ， 其 运行 结果 如 图 14.22 所 示 。 
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Wy 


明日 购物 空间 
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图 14.22 Smarty+ADODB 完成 数据 的 分 页 显示 


图 关键 技术 

应 用 Smarty+ADODB 完成 数据 的 分 页 显示 ， 涵 盖 了 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 的 
分 页 技术 , 而 Smarty 依旧 是 将 ADODB 操作 MySQL 获取 到 的 数据 通过 assign0 方 法 传递 给 模板 变量 , 然后 在 模 
板 页 中 应 用 section 语句 循环 输出 数据 。 
其 中 有 关 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 分 页 技术 的 详细 讲解 请 读者 参考 本 书 第 13 章 
的 内 容 ， 这 里 不 再 歼 述 。 
在 本 实例 中 ， 将 Smarty 的 配置 方法 以 及 ADODB 连接 和 操作 数据 库 的 方法 都 存储 在 system.smarty.inc.php 
文件 中 ; 将 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 的 实例 化 存储 在 system.inc.php 文件 中 ; 将 Smarty 的 编译 文 
件 、 配 置 文件 和 缓存 文件 的 存储 目录 放置 在 Smarty 文件 夹 下 ; 而 将 Smarty 类 库 和 ADODB5 类 库存 储 在 实例 根 
目录 的 同 级 目录 下 。 本 实例 的 文件 夹 架构 如 图 14.23 所 示 。 


日 国 站 点 - mr 了 :WppSeryvnmWRV14) 


a sn 实例 根 目 录 
四 加 oss Css 样式 文件 夫 
丁目 inset 一 一 一 一 一 一 一 一 一 一 一 一 图 片 文件 夫 
a 本 肢 本 文件 夫 
名 上 传 图 片 存储 文件 夫 
= 人 配置 文件 存储 文件 志 
日 Sear ty 生成 文件 存 迁 文件 夫 


组 存 文件 卖 


本 system 


丽 index html 


图 14.23 本 实例 的 文件 夹 架构 


图 设计 过 程 


(1) 创建 system 文件 夹 ， 存 储 ADODB 类 库 和 Smarty 模板 文件 。 创 建 system.smarty.inc.php 文件 ， 定 义 
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数据 库 连 接 类 、 数 据 库 操 作 类 和 分 页 类 。 

数据 库 连 接 类 ConnDB ， 定 义 构造 方法 ConnDB 为 成 员 变 量 赋值 ， 定义 GetConnId0 方 法 ， 应 用 
NewADOConnection() 函 数 连接 MySQL、mssql 或 者 Access 数据 库 ， 设 置 数据 库 编 码 格式 为 utf-8， 最 后 返回 数 
据 库 连接 对 象 ， 定 义 CloseConnId0 方 法 ， 关 闭 与 数据 库 的 连接 。 

数据 库 操作 类 AdminDB， 定 义 Bes QL i 首先 ， 通 过 substr0 
函数 截取 SQL 语句 中 前 6 个 字符 串 ， 并 将 截取 的 字符 串 转 换 成 小 写 。 然 后 ， 通 过 Execute0 函 数 执行 SQL 语句 。 
最 后 ， 根 据 截取 的 字符 串 判 断 SQL 语句 的 类 型 ， 如 果 是 select i 则 执行 GetRows0 函 数 ， 如 果 查 询 结 
果 为 0， 则 返回 FALSE， 和 否则 返回 查询 的 数组 如果 SQL 语句 为 update、insert 或 者 delete 类 型 ， 执 行 成 功 则 
返回 TRUE， 否 则 返回 FALSE。 

分 页 类 SepPage， 定 义 ShowDate0 方 法 完成 从 数据 库 中 读 取 数据 的 操作 ， 执 行 PageExecute0 函 数 实现 分 页 
功能 ， 并 且 将 返回 值 定义 到 数组 中 ;定义 ShowPage0 方 法 根据 查询 结果 ， 应 用 分 页 函数 创建 分 页 超 链 接 ， 并 且 
将 返回 结果 定义 到 变量 $str 中 。 

Smarty 配置 类 SmartyProject， 继 承 Smarty 类 库 中 Smarty 类 ， 设 置 本 实例 中 Smarty 缓存 文件 、 配 置 文件 、 
模板 文件 和 编译 文件 的 存储 位 置 。 

system.smarty.inc.php 文件 的 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 这 里 不 再 介绍 。 

(2) 创建 system.inc.php 文件 ， 完 成 对 数据 库 连 接 、 操 作 、 分 页 以 及 Smarty 配置 类 的 实例 化 操作 ， 其 代码 


如 下 : 
<?php 
require("system.smarty.inc.php"); // 包 含 配 置 类 文件 
$smarty=new SmartyProject(); /实例 化 配置 类 
$connobj=new ConnDB("mysql","localhost","root","111","db_database14",false); /实例 化 数据 库 连接 类 

Sconn=$connobj->GetConnId(); 

$admindb=new AdminDBO; // 实 例 化 数据 库 操作 类 
$seppage=new SepPage(); /实例 化 分 页 类 
> 


至 此 ， 有 关 ADODB 和 Smarty 的 安装 和 配置 方法 介绍 完毕 。 
(3) 创建 index.php 文件 ， 调 用 分 页 类 中 的 ShowDate0 方 法 ， 分 页 读 取 数 据 库 中 的 数据 ， 并 且 将 返回 值 赋 
给 模板 变量 ， 调 用 分 页 类 中 的 ShowPage0 方 法 ， 完 成 分 页 超 链 接 的 输出 ， 同 样 将 返回 值 赋 给 模板 变量 ， 最 后 指 
ee 页 ， 其 代码 如 下 : 
once("systemy/system.inc.php"); /包含 配置 文件 
$arraybbs=$seppage->ShowDate("select * from tb_commo where isnew = 1 order by id ".$conn.3,$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 功能 
if(!$arraybbs){ 
ee 
Ssmarty->assign("isbbs","T"); 
$smarty->assign("showpage",$seppage->ShowPage(" 商 品 "," 个 ","","a1")); /定义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("arr",Sarraybbs); 
$smarty->assign('title'"'Smarty+Adodb 完成 数据 分 页 显示 人 ); 
Ssmarty->display(index html): 
?> 
(4) 创建 index.html 模板 文件 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 。 
(5) 创建 showcommo.html 和 showcommo.php 文件 ， 用 于 输出 指定 产品 的 详细 信息 


图 秘笈 心 法 


心 法 领悟 571: 在 模板 页 中 嵌入 PHP 脚本 。 
在 Smarty 模板 页 中 也 可 以 嵌入 PHP 脚本 , 应 用 的 是 Smarty 中 的 PHP 标签 。 PHP 标签 中 的 语句 是 否 被 处 理 
取决 于 $php_handling 的 设置 。 通 常情 况 下 是 不 需要 在 模板 页 中 嵌入 PHP 脚本 的 ， 但 是 不 代表 不 可 以 使 用 。 
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时 间 的 格式 化 输出 


图 实例 说 明 


在 PHP 脚本 中 ， 完 成 日 期 、 时 间 的 格式 化 输出 最 常用 的 是 date0 函 数 ， 那 么 在 Smarty 模板 中 该 如 何 完 成 日 
期 、 时 间 的 输出 呢 ? 这 就 是 本 实例 要 讲解 的 内 容 ， 即 通过 Smarty 模板 中 的 date format 函数 完成 日 期 、 时 间 的 
格式 化 输出 ， 其 运行 结果 如 图 14.24 所 示 。 


网 8 J 个 者 有 逢 个 第 3 本 并 2 页 首页 上 一 本 下 一 开展 


图 14.24 Smarty 模板 中 日 期 的 格式 化 输出 


图 关键 技术 


(1) Smarty 模板 中 的 date_format 函数 ， 格 式 化 从 函数 strftime() 获 得 的 时 间 和 日 期 ， 其 应 用 示例 如 下 : 
{$smarty.nowldate_format:"%A, %B %e, %Y":$times} 
参数 说 明 : 
$smarty.now: 传递 给 date_format 的 数据 。 这 个 参数 可 以 是 在 PHP 动态 页 中 定义 的 日 期 、 时 间 模 板 变 量 ， 
也 可 以 使 用 Smarty 中 的 保留 变量 $smarty.now 或 者 Smarty 模板 中 的 日 期 。 
%A, %B %e, %Y: date_format 函数 执行 格式 化 操作 时 使 用 的 格式 。 
$times: 当 传 递 给 date_format 的 数据 为 空 时 ， 通 过 $times 设置 date_format 格式 化 的 默认 值 。 
(2) date format 函数 可 以 使 用 的 转换 格式 很 多 ， 其 常用 的 转换 格式 说 明 如 下 : 
%a - 根据 当地 格式 输出 “星期 ”缩写 格式 
%A - 根据 当地 格式 输出 “星期 ”全 称 格式 
%b - 根据 当地 格式 输出 “月 ”缩写 格式 
%B - 根据 当地 格式 输出 “月 ”全 称 格 式 
%Y - 根据 当地 格式 输出 “年 ”全 称 格式 


要 了 解 date_format 函数 所 有 可 以 使 用 的 转换 格式 ， 建 议 读者 参考 Smarty 模板 的 参考 手册 。 
图 设计 过 程 

本 实例 继续 使 用 实例 571 的 内 容 ， 在 index.html 模板 文件 中 插入 date_format 函数 ， 输 出 系统 的 当前 时 间 ， 
其 关键 代码 如 下 : 

<td width="480" height="18" align="left"> 当 前 时 间 : {$smarty.nowldate_format:" %A %B-%e-%Y"}</td> 

<!--{Ssmarty nowldate format} 

{$smarty.nowldate format"96A. %B %e, 9%6Y":Stimes} 


{Ssmarty nowldate format"96H:96M:96S" 
{Syesterdayldate_format} 
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和 format:"%A, WB %e, MWY"} 
本 实例 的 其 他 内 容 可 以 参考 实例 571， 这 里 不 再 歼 述 。 
图 秘笈 心 法 


心 法 领悟 S72: date format 函数 的 妙用 。 

通过 date_ format 函数 不 但 可 以 输出 系统 的 当前 时 间 ， 如 果 配 合 strtotime0 函 数 ， 还 可 以 获取 其 他 时 间 。 例 
如 ， 获 取 系 统 前 一 天 的 时 间 ， 其 方法 如 下 : 

首先 在 index.php 中 ， 应 用 strtotime0 函 数 获取 前 一 天 的 时 间 惟 ， 并 且 将 时 间 戳 赋 给 模板 变量 。 然 后 在 


index.html 模板 页 中 ， 应 用 date_format 函数 格式 化 输出 前 一 天 的 时 间 ， 其 关键 代码 如 下 : 
/Index.php 文 件 
Ssmarty->assign('yesterday’, strtotime(-1 day); 
WIndex.html 文件 
{$ yesterday |date_format:" %6A = %B - %e - %Y"} 


实例 573 


实例 说 明 


在 PHP 脚本 中 应 用 urlencode0 函 数 对 超 链接 中 传递 的 参数 进行 编码 ， 而 在 Smarty 模板 中 提供 escape 函数 
对 字符 串 进 行 编码 。 本 实例 将 详细 讲解 该 函数 的 应 用 ， 通 过 它 对 超 链接 中 传递 的 参数 进行 编码 ， 其 运行 结果 如 
图 14.25 所 示 。 
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14.25 ”Smarty 模板 中 对 超 链接 的 参数 值 进 行 编码 


图 关键 技术 


escape 变量 用 于 html 转 码 、url 转 码 ， 在 没有 转 码 的 变量 上 转换 单 引 号 、 十 六 进 制 转 码 或 者 javascript 转 码 ， 
默认 是 html 转 码 ， 其 基本 的 应 用 格式 如 下 : 

{SarticleTitlelescape} 

{SarticleTitlelescape:"html"} {* escapes & "'<>*} 

{SarticleTitlelescape:"htmlall"} {* escapes ALL html entities +} 

{SarticleTitlelescape:"url"} 

{SarticleTitlelescape:"quotes"} 

<a href="mailto: {$EmailAddresslescape:"hex"}">{$EmailAddresslescape:"hexentity"}</a> 
图 设计 过 程 

(1) 这 里 仍然 应 用 实例 568 中 的 内 容 ， 为 不 同 模块 之 间 跳 转 的 超 链接 传递 的 参数 值 编码 ， 其 具体 的 操作 在 

main.html 模板 页 中 完成 ， 关 键 代码 如 下 : 
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<map name= "Map" id="Map"> 

<area shape="rect" coords="29.41.88.62" href="main.php?caption={" 商 品 添加 "|escape:"url"}&amp;type={" 商 品 管理 "}" /> 

<area shape="rect" coords="30,71.91,90" href="main.php?caption={" 商 品 修改 "|escape:"url"}&amp;type={" 商 品 管理 "}" /> 

<area shape="rect" coords="31.99.91.118" href="main.php?caption={" 商 品 删 除 "|escape:"url"}&amp:type={" 商 品 管理 "}" /> 

</map> 

<map name="Map2" id="Map2"> 

<area shape="rect" coords="30,45,97.63" href="main.php?caption={" 会 员 删 除 "|escape:"url"}&amp;type={" 会 员 管 理 "}" /> 

<area shape="rect" coords="34.80,89,98" href="main.php?caption={" 会 员 浏览 "lescape:"url"}&amp;type={" 会 员 管 理 "}" /> 

/map> 

<map name="Map5" id="Map5"> 

<area shape="rect" coords="12,11,54,36" href="logout.php" /> 

</map> 

<map name="Map6" id="Map6"> 

<area shape="rect" coords="14,12,51,36" href="main.php?caption={" 商 品 修改 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 

</map> 

(2) 虽然 通过 escape 编码 后 的 模板 变量 输出 时 是 乱码 ， 但 是 在 switch 语句 中 仍然 可 以 直接 使 用 

$_GET['caption'] 获 取 超 链接 的 值 ， 根 据 这 个 值 作出 判断 ， 在 主页 中 输出 相应 模块 的 内 容 ， 不 需要 对 这 个 参数 值 
进行 解码 。 

执行 判断 是 在 main.php 文件 中 完成 的 ， 其 关键 代码 如 下 : 


<?php 
Session_start0: // 初 始 化 SESSION 变量 
if($_SESSION['user]!="" and $_SESSION['pass]!=""){ /1/ 判 断 用 户 名 和 密码 是 否 为 宝 
require("system/system.inc.php"); // 包 含 PHP 配置 文件 
switch ($_GET['captionD) { // 根 据 超 链接 传递 的 值 进行 判断 
case "商品 添加 "; 
include "sho_insert.php"; // 包 含 PHP 文 件 
S$smarty->assign(admin phtml','sho_insert.html’); // 将 PHP 文件 对 应 的 模板 文件 的 名 称 赋 给 模板 变量 
break: /跳出 循环 
/| 省 略 了 部 分 代码 
default: 
include "sho_update.php"; 
$smarty->assign(admin_phtml','sho_update.html"); 
} 
Ssmarty->assign("title"," 后 台 管 理 系统 --".$_GET[caption”]): // 为 模板 变量 赋值 
$smarty->assign("caption",$_GET['caption']): // 为 模板 变量 赋值 ， 输 出 模块 名 称 
Ssmarty->assign("type",$_GET['type’]); // 为 模板 变量 赋值 ， 输 出 模块 所 属 类 别 
$smarty->assign("user",$_SESSION[mser]): /为 模板 变量 赋值 ， 输 出 登录 用 户 名 称 
S$smarty->display("main.html"); /指定 模板 页 
jelse{f 
echo "<script>alert( 您 不 具备 访问 权限 ! ); window.location href='index.html';</script>"; 
} 
> 


3) 有 关 本 实例 中 Smarty 模板 的 配置 、 数 据 库 的 连接 和 操作 ， 以 及 用 户 登 录 模 块 和 子 模块 的 创建 方法 ， 
请 读者 参考 实例 568， 这 里 不 再 袭 述 。 
图 秘笈 心 法 

心 法 领悟 573: escape 编码 的 重要 性 。 

经 过 escape 变量 编码 后 的 字符 串 ， 在 输出 时 将 是 一 堆 乱码 ， 在 超 链接 中 通过 这 种 方法 可 以 保证 参数 值 的 安 
全 传递 。 


je 高 级 
实例 574 未 扣 妆 :让 二 


力 实例 说 明 
本 实例 讲解 Smarty 模板 中 正则 表达 式 的 应 用 ， 通 过 该 方法 在 Smarty 模板 页 完成 字符 串 的 蔡 换 操作 。 本 实 
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例 以 实例 569 为 基础 ， 将 分 页 输出 的 会 员 名称 mr 替换 为 明日 科技 ， 运 行 结果 如 图 14.26 所 示 。 


ESE 
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图 14.26 ”Smarty 模板 中 正则 表达 式 的 运用 


图 关键 技术 


regex_replace 为 Smarty 模板 中 的 正则 表达 式 ， 可 对 指定 的 字符 串 进 行 匹 配 ， 其 包括 两 个 参数 : 第 一 个 是 指 
定 的 正则 表达 式 ， 第 二 个 是 指定 的 替换 文本 ， 其 应 用 示例 如 下 : 


{$namelregex_replace:"/[mr]/":"<font color=#FF0000> 明 日 科技 </font>"} 
在 这 个 示例 中 ， 将 模板 变量 $name 中 的 mr 蔡 换 为 <font color=#FF0000> 明 日 科技 </font>。 


图 设计 过 程 

这 里 以 实例 570 的 内 容 为 基础 ， 对 会 员 浏览 模块 的 内 容 进 行 重新 编辑 ， 分 页 输出 会 员 浏览 的 数据 ， 并 且 应 
用 regex_replace 变量 将 会 员 名 称 中 的 mr 替换 为 明日 科技 。 

(1) 编辑 vip_look.php 文件 ， 分 页 读 取 数据 库 中 存储 的 会 员 数 据 ， 并 且 将 分 页 读 取 返回 的 变量 赋 给 模板 变 
量 ， 最 终 指 定 模板 页 ， 其 关键 代码 如 下 : 


<2php 
include_once "conn/conn php"; /连接 数据 库 
require_once("system/system.inc.php"); /调用 指定 的 文件 


/执行 查询 语句 ， 从 数据 库 中 读 取 商 品 信息 
S$sql=mysql_query("select count(*) as totall from tb_name ",$conn); 
$info=mysql_fetch_array($sql); 


Stotall=$infoftotall]; /| 统计 数据 库 中 数据 总 数 
if(empty($_GET[pages])=tme || is_numeric($_GET[pages])—false){ /判断 变量 pages 是 否 为 空 
S$pagel=1: /如 果 变 量 为 室 ， 则 赋值 为 1 
yelse{ /如 果 不 为 室 ， 则 获取 变量 的 值 
$pagel=intval($_GET[pages]): 
} 
Spagesizel=3; /定义 每 页 显示 3 条 记录 
if($totall<$pagesizel){ /1/ 判 断 如 果 数 据 库 中 数据 小 于 每 页 显示 的 记录 数 
Spagecount1=1; // 则 定义 pagecount 变量 的 值 为 1 
yelse{ 
if($totall%Spagesizel—0){ 
Spagecount1=intval($totall/$pagesize1): 1/ 用 总 的 记录 数 除 以 每 页 显示 的 记录 数 ， 获 取 共有 几 页 
Jelse{ 
Spagecount1=intval($totall/$pagesizel)+1; 
} 
} 
/将 要 输出 的 数据 赋 给 assign 模板 变量 
Ssmarty->assign("total1".$total1); 
Ssmarty->assign("pagesizel".$pagesizel): 
$smarty->assign("pagel".$pagel); 


Ssmarty->assign("pagecountl".Spagecountl): 

Squery=mysql_query("select + from tb_name order by id desc limit " (Spagel-1)*Spagesizel.".Spagesizel"Sconn ); 
Smyrow=mysql fetch_array($query): 

Sarray=arrayO:; // 定 义 一 个 空 数组 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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在 这 个 示例 中 ， 将 模板 变量 $articleTitle 中 的 Garden 替换 为 Vineyard。 
(2) 查询 关键 字 描 红 的 原理 : 在 PHP 动态 页 中 获取 form 表单 提交 的 查询 关键 字 ， 并 且 执 行 模糊 查询 ， 将 
查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 模板 变量 ， 然 后 在 模板 页 中 ， 通 过 section 语句 循环 输出 查 
询 结果 ， 并 应 用 replace 变量 将 查询 结果 中 关键 字 的 字体 设置 为 红色 。 
图 设计 过 程 
这 里 以 实例 570 的 内 容 为 基础 ， 对 订单 查询 模块 的 内 容 进行 重新 编辑 ， 创 建 form 表单 执行 查询 操作 ， 并 且 
应 用 replace 变量 将 查询 结果 中 的 关键 字 描 红 。 
(1) 编辑 for_select.html 模板 页 ， 创 建 form 表单 ， 提 交 查 询 的 关键 字 ， 将 数据 提交 到 for_selectphp 页 面 进 
行 处 理 ， 同 时 在 本 页 中 应 用 section 语句 循环 输出 查询 结果 ， 并 且 应 用 replace 对 查询 的 关键 字 进 行 描 红 操作 ， 
其 关键 代码 如 下 : 


{section name=id loop=S$res} 
<t> 


<td align="center" bgcolor="#FFFFFF">{$res[id].id} </td> 
<td bgcolor="#FFFFFF">{$res[idl.numberireplace:$select:"<font color=#FF0000'>$select</font>"} 
<itd> 
<td bgcolor="#FFFFFF">{$res[id].userlreplace:" 明 日 科技 "<font color=#FF0000> 明 日 科技 </font>"}</td> 
<td bgcolor="#FFFFFF">{$res[idl.dates}</td> 
<td align="center" bgcolor="#FFFFFF">{if $res[id].type 一 0} 未 处理 {else} 已 处 理 {/i}</td> 
</t> 
{/section} 
(2) 编辑 for_select.php 动态 页 ， 以 form 表单 中 提交 的 关键 字 为 条 件 ， 执 行 模糊 查询 ， 如 果 查 询 结 果 为 真 ， 
则 将 查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 指定 的 模板 变量 ; 如果 查询 结果 为 FALSE， 则 为 模板 
变量 赋值 F， 其 代码 如 下 : 


<?php 
$smarty->assign(title,"Smarty 模板 中 的 关键 字 描 红 技术 "); /定义 标题 变量 
if($_POST['number]!=""){ // 浏 断 查询 关键 字 是 否 为 空 
$sql="select * from tb_order where number like '%".S_POST[mumber]."9%6": // 定 义 模糊 查询 的 语句 
Sres=$admindb->ExecSQL($sql.$conn); / 呐 行 模糊 查询 
这 Sres){ 
S$smarty->assign("select",S_POST[mumber]): /将 查询 的 关键 字 赋 给 模板 变量 
Ssmarty->assign("boo"."T"); // 为 模板 变量 赋值 
Ssmarty->assign("res", Sres); // 将 查询 结果 赋 给 模板 变量 
Jelse{ 
$smarty->assign("boo","F"): 
} 
jelse{f 
a 
> 
图 秘笈 心 法 


心 法 领悟 575: replace 变量 的 妙用 。 
通过 replace 变量 不 但 可 以 实现 查询 关键 字 描 红 的 功能 ， 而 且 可 以 实现 替换 论坛 中 的 非法 关键 字 的 功能 ， 其 
实现 方法 与 关键 字 的 描 红 是 相同 的 。 
输出 字符 串 的 行 宽 高 级 
趣味 指数 : 会合 富商 | 


实例 576 


国 实例 说 明 
在 Web 页 面 中 ， 通 常 应 用 CSS 样式 来 控制 字符 串 输出 的 行 宽 ， 而 在 Smarty 模板 中 却 有 一 个 变量 可 以 完成 
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这 个 功能 ， 即 wordwrap。 在 本 实例 中 将 讲解 这 个 变量 的 应 用 ， 并 且 通 过 它 控制 页 面 中 输出 字符 串 的 行 宽 ， 其 运 
行 结果 如 图 14.28 所 示 。 
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明日 编程 词典 ee 
图 14.28 每 行 显示 30 个 字符 串 的 运行 效果 


图 关键 技术 


wordwrap 指定 段落 的 宽度 〈 即 控制 一 行 显示 多 少 个 字符 ， 如 果 超 过 这 个 字符 数 则 换行 ) ， 其 默认 值 是 80 
字符 。 该 方法 包含 3 个 参数 : 

第 1 个 参数 设置 每 行 显示 的 字符 数 ， 

第 2 个 参数 设置 在 约束 点 使 用 什么 字符 〈 默 认 值 是 换行 符 m) ; 

第 3 个 参数 控制 Smarty 是 截取 到 字符 串 的 末尾 ， 还 是 精确 到 指定 长 度 的 字符 ， 默 认 情 况 是 截取 到 字符 串 的 
默认 值 ， 如 果 设 置 第 3 个 参数 的 值 为 TRUE， 那么 就 精确 截取 到 指定 长 度 的 字符 ， 其 应 用 的 示例 如 下 : 

{SarticleTitielwordwrap:30} 

设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 。 

{SarticleTitlelwordwrap:30:"<br>\n"} 

设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 <br>\n 进行 换行 操作 。 

{SarticleTitlelwordwrap:30:"\n":true} 

设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 ， 同 时 精确 截取 30 个 字符 。 

上 述 示例 是 对 模板 变量 $articleTitle 中 存储 的 数据 进行 操作 。 
图 设计 过 程 

(1) 创建 system 文件 夹 。 首 先 ， 定 义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 。 然 后 ， 定 义 
system.inc.php 文件 ， 对 Smarty 配置 类 进行 实例 化 ， 并 返回 连接 对 象 。 最 后 ， 创 建 Smarty 文件 夹 ， 定 义 Smarty 
的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 index.php 文件 。 首先， 设置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 ， 通 过 fe_get_contentsO 函 
数 读 取 存储 在 文本 文件 content.txt 中 的 字符 串 ， 并 应 用 iconv0 函 数 将 字符 串 的 gb2312 编码 转换 为 utf-8 编码 ， 
同时 将 转换 后 的 文件 存储 到 模板 变量 中 ， 最 终 指定 模板 页 ， 代 码 如 下 : 


<2php 

header ( "Content-type: 全 charset=UTF-8" ); /设置 文件 编码 格式 
include("systemy/system_inc .php' /包含 配置 文件 
$smarty->assign('title','Smarty 有 的 行 宽 人 /定义 实例 标题 变量 
$str = file_get_contents('files/content.txt’): 1/ 读 取 文 本 文件 中 的 数据 
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$smarty->assign('‘content'iconv("gb2312","utf-8",$str)):; /将 文本 文件 中 的 数据 存储 到 模板 变量 中 
S$smarty->display(index html): /指定 模板 页 
> 


(3) 创建 index.html 模板 页 ， 通 过 模板 变量 输出 文本 文件 中 的 字符 串 ， 并 且 应 用 wordwrap 控制 每 行 显示 
30 个 字符 ， 应 用 <br>v 完成 换行 操作 ， 其 关键 代码 如 下 : 
{Scontentlwordwrap:30:"<br>\n"} 


力 秘笈 心 法 


心 法 领悟 576: Smarty 模板 中 换行 符 的 转换 。 

在 应 用 wordwrap 控制 段落 中 每 行 显示 的 字符 时 ， 默 认 使 用 为 换行 符 。 但 是 ， 使 用 \n 作为 换行 符 ， 在 页 面 
中 看 不 到 字符 串 换行 的 效果 ， 只 有 在 查看 源 文件 时 才能 看 出 字符 串 已 经 换行 ， 所 以 , 在 应 用 wordwrap 控制 段落 中 
每 行 显示 的 字符 时 ， 应 该 设置 第 2 个 参数 ， 指 定 <br> 为 换行 符 ， 这 样 在 页 面 中 就 可 以 直接 看 到 段落 换行 的 效果 。 

在 Smarty 模板 中 , 还 可 以 通过 nl2br 将 所 有 的 换行 符 转换 成 </br>, 其 使 用 方法 与 PHP 中 的 nl2br0 函 数 相同 。 
而 本 实例 中 的 字符 串 换行 操作 也 可 以 使 用 如 下 方法 来 完成 : 

{Scontentlwordwrap:30lnl2br} 


图 实例 说 明 

在 PHP 中 ， 可 以 通过 function 创建 自 定 义 函 数 ， 完 成 一 些 特殊 的 操作 ， 同 样 在 Smarty 中 可 以 通过 
Tegister_object( 方 法 注册 对 象 , 在 模板 页 中 完成 一 些 特殊 的 操作 。 在 本 实例 中 通过 register_object0 方 法 注册 对 和 象 ， 
定义 方法 moneyFormat0 和 unHtml0， 分 别 对 留言 本 中 的 评分 进行 转 义 保留 两 位 小 数 ) 及 对 留言 内 容 中 的 html 
标记 进行 转 义 ， 其 运行 结果 如 图 14.29 所 示 。 
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图 14.29 评分 和 html 标记 转 义 后 输出 


图 关键 技术 


(1) register_object0 方 法 ， 注 册 一 个 在 模板 中 使 用 的 对 象 ， 语 法 如 下 : 
void register_object (string object_name., object Sobject array allowed methods/properties. boolean format, array block methods) 
register_object 注册 对 象 的 参数 说 明 如 表 14.5 所 示 。 
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表 14.5 register_object 注册 对 象 的 参数 说 明 
参数 说 了 明 


object_name | ”模板 页 中 使 用 的 对 象 名 称 
Sobject | 实例 化 的 对 象 名 称 


定义 允许 使 用 的 方法 ， 如 果 设 置 为 null， 表 示 所 有 方法 都 可 用 
format 设置 对 象 参数 传递 的 方法 ， 如 果 值 为 flse， 则 表示 一 次 传递 一 个 参数 


block methods 该 参数 在 format 的 值 为 tue 应 用 ， 向 对 象 中 添加 一 个 块 方法 


对 象 注 册 成 功 后 ， 就 可 以 在 模板 页 中 通过 对 象 名 称 调用 对 象 中 的 方法 ， 完 成 对 指定 数据 的 操作 。 本 实例 在 
模板 页 中 通过 Util 对 象 分 别 调用 moneyFormatO0 和 unHtml0 方 法 ,完成 对 留言 本 中 评分 和 内 容 的 转 义 , 其 关键 代 
码 如 下 : 


{if $iscommo=—"T"} 
<table width="500" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#0099CC"> 
{section name=id loop=$array} 
<t> 
<td>{Util->unHtml pt=$array[id].id } 

{Util->unHtml pt=$array[id].title } 
评分 {Util->moneyFormat pt=$array[id].integral} 
<br> {Util->unHtml pt=$array[id].content} 
</td> 

<t> 
{/section} 
</table> 
{ 认 

(2) str replace0 函 数 ， 实 现 字符 串 的 替换 ， 其 语法 如 下 : 

mixed str_replace ( mixed search, mixed replace, mixed subject , int &count ) 
str_replace0 函 数 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 替换 ， 参 数 &count 表示 替换 字符 串 执 


行 的 次 数 。str_replace0 函 数 的 参数 说 明 如 表 14.6 所 示 。 
表 14.6 str_replace() 函 数 的 参数 说 明 


allowed methods/properties 


参数 说 了 明 
search 指定 将 要 被 替换 的 字符 
Teplace 指定 替换 所 使 用 的 字符 
subject 指定 被 操作 的 字符 串 


&count 替换 字符 串 执行 的 次 数 


(3) number formatO 函 数 ， 将 数字 字符 串 格式 化 ， 其 语法 如 下 : 
string number format ( float number , int decimals) 
string number format ( float number, int decimals, string dec_point, string thousands_sep) 


number formatO 函 数 返 回 参数 number 格式 化 后 的 字符 串 ， 该 函数 可 以 有 1 个 、2 个 或 者 4 个 参数 ， 但 不 能 
是 3 个 参数 。 

如 果 只 有 1 个 参数 ，number 格式 化 后 会 舍 去 小 数 点 后 的 值 ， 且 每 一 千 就 会 以 逗号 “,” 来 隔 开 ， 

如 果 有 2 个 参数 ，number 格式 化 后 会 到 小 数 点 第 decimals 位 ， 且 每 一 千 就 会 以 逗号 “,” 来 隔 开 ; 

如 果 有 4 个 参数 , number 格式 化 后 会 到 小 数 点 第 decimals 位 ,dec_point 用 来 蔡 代 小 数 点 “.”, thousands_sep 
用 来 替代 每 一 千 隔 开 的 逗号 “,”。 


图 设计 过 程 


(1) 创建 system 文件 夹 , 定义 Smarty 文件 夹 , 存储 编译 目录 、 缓 存 目录 : 创建 类 文件 system.smarty.inc.php， 
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定义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 ， 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 包 含 类 的 实例 化 操作 文件 ;创建 类 ， 定 义 评分 转 义 和 html 标记 转 义 的 方法 ， 通 
过 register_ object 注册 模板 对 象 ， 完 成 数据 库 中 数据 的 分 页 读 取 ， 最 终 指 定 模板 页 ， 其 代码 如 下 : 


<?php 
require_once("system/systen inc.php"): // 调 用 指定 的 文件 
class Utl { 
function moneyFormat(SintegraD { /将 数字 转换 成 有 两 位 小 数 的 形式 


Teturn str replace ( ',, ", number format ( $integral, 2 ) ); 
. 
function unHtml($text) { /转换 字符 串 中 的 html 标签 
S$str = htmlspecialchars ( $text ); 
S$str = ereg_replace ( '<br>", \nm', $str ); 
S$str = nl2br ( $str ); 
Sstr = ereg_replace ('', ‘&nbsp:', $str ); 


Teturn $str 

} 
} 
Sntil=new UtilO; // 实 例 化 对 象 
$smarty->register_object("Util", $ntil,null,false); /注册 模板 对 和 象 
Sarray=$seppage->ShowDate("select * from tb_guestbook order by id desc",$conn,2,$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 
这 !$array){ 

Ssmarty->assign("iscommo","F"); 1/ 判断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
jelse{ 

S$smarty->assign("iscommo","T"); /判断 如 果 执行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 


$smarty->assign("showpage",$seppage->ShowPage(" 留 言 "" 条 ","","a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
$smarty->assign("array", Sarray); 
} 
$smarty->assign('title',register_object0 方 法 注册 模板 对 象 ”); 
$smarty->display('index.html); 
> 
(3) 创建 index.html 模板 页 ， 分 页 输出 模板 变量 中 传递 的 数据 ， 并 且 调 用 注册 模板 对 象 中 的 方法 ， 对 评分 
和 html 标记 进行 转换 操作 。 同 时 创建 一 个 form 表单 ， 用 于 提交 留言 信息 ， 将 数据 提交 到 index_ok.php 文件 中 。 
关键 代码 请 参考 关键 技术 中 的 内 容 。 
(4) 创建 ndex_ok.php 文件 ， 将 表单 中 提交 的 留言 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
Tequire_once("system/systeni inc.php"); // 调 用 指定 的 文件 
Stitle=$_POST[title]: /获取 标题 
Scontent=$_POST[content]: /获取 内 容 
Sintegral=$_POST[integral]: 

Screatetime=date("Y-m-j H:i:s"): // 定 义 时 间 


Sarr=$admindb->ExecSQL("insert into tb guestbook(title.content.createtime.integral) values ('$title','$content',$createtime','S$integral’)",$conn); 
if(San){ 
echo "<script>alert(' 留 言 发 表 成 功 !");window.location.href~'index.php':</script>"; 
jelsef 
echo "<script>alert( 留 言 发 表 失败 !"):history.back0:</script>"; 
} 
> 


图 秘笈 心 法 


心 法 领悟 577: 模板 对 象 的 注销 。 
在 Smarty 模 板 中 ,不 但 可 以 注册 模板 对 象 , 而 且 可 以 注销 模板 对 象 ,注销 模板 对 象 应 用 的 是 unregister_objectO 
方法 。 
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力 实例 说 明 

本 实例 讲解 在 Smarty 中 注册 模板 函数 的 方法 。 模 板 函 数 可 以 实现 与 PHP 中 自 定义 函数 相同 的 功能 ， 其 特 
点 是 注册 在 动态 页 中 完成 ， 实 际 的 应 用 在 静态 页 中 进行 ， 完 全 体现 Smarty 的 动静 分 离 的 开发 模式 。 本 实例 分 页 
输出 论坛 帖子 的 信息 ， 如 果 帖 子 内 容 超出 指定 的 长 度 ， 就 通过 注册 模板 函数 对 其 进行 截取 ， 并 且 使 用 省 略 号 蔡 
代 被 截取 部 分 ， 其 运行 结果 如 图 14.30 所 示 。 
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图 14.30 ”注册 模板 函数 截取 字符 串 


图 关键 技术 
(1) register_function() 方 法 ， 动 态 注 册 模板 函数 插件 ， 语 法 如 下 : 
Void register function (string name, mixed impl, bool cacheable, array or null cache_attrs) 
register_function0 方 法 的 参数 说 明 如 表 14.7 所 示 。 


表 14.7 register_function 方法 的 参数 说 明 


参 数 说 阴 

name 模板 函数 的 名 称 
执行 函数 的 名 称 。 执 行 函数 的 格式 可 以 是 一 个 包含 函数 名 称 的 字符 串 ， 也 可 以 是 一 个 array(&$object, 

impl $method) 数 组 形式 , 其 中 &$object 是 一 个 对 象 的 引用 ,而 Smethod 是 对 象 的 一 个 方法 ;还 可 以 是 一 个 array(&$ 
class, Smethod) 数 组 形式 ， 其 中 $class 是 一 个 类 的 名 称 ，$method 是 类 中 的 一 个 方法 

cacheable 可 选 参数 ， 大 多 数 情况 下 可 以 省 略 

cache attrs | 可 选 参数 ， 大 多 数 情况 下 可 以 省 略 

(2) extract0 函 数 ， 从 数组 中 将 变量 导入 到 当前 的 符号 表 中 ， 语 法 如 下 : 


int extract ( array var_array [. int extract_type [. string prefix]] ) 

本 函数 用 来 将 变量 从 数组 中 导入 到 当前 的 符号 表 中 .接受 结合 数组 var_array 作为 参数 并 将 键 名 当 作 变量 名 ， 
值 作为 变量 的 值 。 对 每 个 键 / 值 对 都 会 在 当前 的 符号 表 中 建立 变量 ， 并 受到 extract_ type 和 prefix 参数 的 影响 。 

函数 extract0 检 查 每 个 键 名 看 是 否 可 以 作为 一 个 合法 的 变量 名 ， 同 时 也 检查 和 符号 表 中 已 有 的 变量 名 的 冲 
突 。 处 理 非法 数字 和 冲突 的 键 名 的 方法 将 根据 extract_type 参数 决定 ， 可 以 是 以 下 值 之 一 : 

EXTR_OVERWRITE: 如 果 有 冲突 ， 履 盖 已 有 的 变量 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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$smarty->register function("Util" "unHtml"); / 往 册 模板 函数 
Sarray=$seppage->ShowDate("select * from tb_guestbook order by id desc".Sconn.6.S_GET["page"]): 


/调用 分 页 类 ， 实 现 分 页 


if(!Saray){ 
S$smarty->assign("iscommo","F"); 
jelsef 
$smarty->assign("showpage".$seppage->ShowPage(" 帖 子 "," 条 ",""."a1")); 
Ssmarty->assign("array", Sarray): 


1/ 判断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
/ 济 断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
/定义 输出 分 页 数据 的 模板 变量 showpage 


} 
$smarty->assign('title',register_finction0 方 法 注册 模板 函数 "): 
$smarty->display(index.html): 
> 
(3) 创建 index.html 模板 页 ， 获 取 模 板 变 量 传递 的 数据 ， 实 现 数据 的 分 页 输出 ， 并 且 调 用 动态 页 中 注册 
的 模板 函数 实现 对 论坛 中 内 容 的 截取 操作 ， 其 关键 代码 如 下 : 
a name=id loop=$array} 
<td colspan="4" bgcolor="#FFFFFF"> {Sarraylid].id }&nbsp;é&nbsp; {Util text=Sarray[id].title } 积 分 : {Sarray[id] .integral} &nbsp;é&nbsp;&nbsp;&nbsp; 
时 间 : {Sarray[id].createtime}<br>{Util text=$array[id].content} </td> 
</t> 


{/section} 
图 秘笈 心 法 


心 法 领悟 578: 字符 串 的 截取 。 

通常 使 用 substr0 函 数 对 字符 串 进 行 截取 ， 但 是 该 函数 在 截取 中 文字 符 串 时 ， 很 可 能 导致 截取 的 中 文字 符 串 
不 完整 ， 出 现 乱 码 的 情况 。 而 本 实例 中 应 用 的 mb_substr0 函 数 ， 同 样 可 以 实现 字符 串 的 截取 功能 ， 且 可 以 对 中 
文字 符 串 进行 截取 ， 不 会 出 现 乱 码 的 问题 。 


实例 579 


力 实例 说 明 


在 Smarty 中 ， 提 供 了 truncate 方法 对 字符 串 进行 截取 ， 该 方法 可 以 截取 到 一 个 词 的 末尾 。 在 本 实例 中 ， 应 


用 truncate 方法 对 论坛 中 标题 和 内 容 进行 截取 ， 并 且 用 省 略 号 替换 截取 的 内 容 ， 其 运行 结果 如 图 14.31 所 示 。 
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图 14.31 truncate 方法 截取 字符 串 


图 关键 技术 


truncate 方法 ， 从 字符 串 开 始 处 截取 指定 长 度 的 字符 ， 默 认 是 80 个 字符 。 应 用 示例 如 下 : 
{SarticleTitleltruncate} <!-- 截 取 默 认 长 度 的 字符 串 -> 
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{SarticleTitleltruncate:30} <!-- 截 取 30 个 字符 -> 

<!-- 截 取 30 个 字符 ， 结 尾 处 默认 使 用 省 略 号 进行 添加 -> 
<!-- 截 取 30 个 字符 ， 结 尾 处 以 “一 ”进行 添加 -> 

<!-- 截 取 30 个 字符 ， 进 行 精确 截取 --> 

<!-- 精 确 截取 30 个 字符 ， 以 省 略 号 进行 添加 -> 


其 中 SarticleTitle 为 模 极 变 量 量 。 
truncate 方法 的 参数 说 明 如 表 14.9 所 示 。 


表 14.9 truncate 方法 的 参数 说 明 


参 数 说 明 
1 第 1 个 参数 ， 指 定 截取 字符 的 数量 ， 类 型 为 Integer 
第 2 个 参数 ， 指 定 截取 后 追加 在 截取 词 后 面 的 字符 串 ， 类 型 为 String 
3 第 3 个 参数 ， 类 型 为 Boolean， 如 果 该 值 为 FALSE， 表 示 截 取 到 词 的 边界 ， 如 果 该 值 为 TRUE， 表 示 截 取 


时 精确 到 指定 字符 


| 设计 过 程 


(1) 创建 system 文件 夹 , 定义 Smarty 文件 夹 , 存储 编译 目录 、 绥 存 目录 ; 创建 类 文件 system.smarty.inc.php， 
定义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 ， 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 分 页 读 取 数 据 库 中 存储 的 论坛 数据 ， 并 且 将 读 取 的 结果 
存储 到 模板 变量 中 ， 最 终 指定 模板 页 ， 其 代码 如 下 : 


<?php 

require_once("system/system.inc.php"); // 调 用 指定 的 文件 

Sarray=$seppage->ShowDate("select * from tb_guestbook order by id desc",$conn,6.$_GET["page"]); // 调 用 分 页 类 ， 实 现 分 页 
if(!$array){ 

$smarty->assign("iscommo","F"); 1/ 判断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
}else{ 

$smarty->assign("iscommo","T"); 1/ 判断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "," 条 "”,"","a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("array", Sarray); 

$smarty->assign('title',truncate 方法 截取 字符 串 小 /定义 标题 

S$smarty->display(index html): /指定 模板 页 

> 


(3) 创建 index.html 模板 页 ， 获 取 模板 变量 传递 的 数据 ， 实 现 数 据 的 分 页 输出 ,并且 通过 truncate 方法 对 
输出 的 标题 和 内 容 进 行 截取 操作 : 标题 截取 30 个 字 节 ， 内 容 截 取 60 个 字 节 ， 应 用 省 略 号 补 齐 截取 部 分 ， 其 关 
键 代码 如 下 : 
{section name=id loop=$array} 
<h> 


<td> 

{Sarray[id].id} {$array[id].titleltruncate:30:"...":false}; 

积分 : {Sarray[id].integral} 

时 间 : {$array[id].createtimeltruncate:12:"" 
{$array[id].contentltruncate:60:"...": 


<htd> 
< 
{/section} 


图 秘笈 心 法 

心 法 领悟 579: 解决 用 truncate 方法 截取 中 文字 符 串 时 出 现 的 乱码 问题 。 

定位 到 Smarty 类 库 的 plugins\modifier.truncate.php 文件 中 , 重新 编辑 smarty_ modifier truncate 方法 , 将 其 中 
截取 字符 串 使 用 的 substr0 函 数 全 部 替换 为 mb_substr0 函 数 。 这 样 在 调用 truncate 方法 截取 中 文字 符 串 时 就 不 会 
出 现 乱码 问题 。 
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图 实例 说 明 


缓存 的 合理 应 用 ， 应 该 以 实际 的 开发 需要 为 依据 ， 对 于 那些 需要 经 常 更 新 的 程序 是 否 开 启 缓存 ， 如 果 开 启 
缓存 ， 周 期 长 短 设置 为 多 少 ， 这 些 都 必须 根据 程序 的 实际 需求 进行 设置 。 在 本 实例 中 ， 开 启 网 站 注册 页 面 的 缓 
存 ， 注 册页 面 的 运行 结果 如 图 14.32 所 示 。 
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图 14.32 注册 页 面 的 运行 结果 


图 关键 技术 


缓存 的 设置 ， 既 要 考虑 可 以 提高 网 站 的 访问 速度 ， 又 要 考虑 缓存 生命 周期 的 合理 性 。 不 能 偏执 一 方 ， 应 该 
采取 中 庸 之 道 ， 达 到 最 理想 的 效果 。 

例如 ， 网 站 首页 是 不 需要 经 常 更 新 的 内 容 ， 缓 存 的 生存 周期 就 可 以 设置 的 长 一 些 ， 而 类 似 于 论坛 中 帖子 的 
数据 ， 则 可 以 不 开启 缓存 ， 因 为 帖子 的 数据 会 不 断 地 更 新 ， 如 果 使 用 缓存 可 能 会 导致 浏览 不 到 最 新 的 数据 。 

(1) 开启 缓存 。 

开启 缓存 的 方法 非常 简单 ， 只 要 将 Smarty 对 象 中 gconfig 的 值 设 置 为 TRUE 即 可 ， 同 时 还 要 通过 Smarty 对 
象 中 的 $cache_dir 属性 指定 缓存 文件 的 存储 位 置 ， 其 操作 代码 如 下 : 


Ssmarty->caching=true; /开启 缓存 
$smarty->cache dir= BASE PATH .SMARTY PATH.'cache/: /定义 缓存 文件 存储 位 置 


(2) 设置 缓存 生命 周期 。 
缓存 创建 成 功 后 ， 必 须 为 其 设置 一 个 生命 周期 ， 如 果 它 一 直 不 更 新 ， 屠 么 就 没有 任何 意义 。 设 置 缓 存 生命 
周期 应 用 的 是 Smarty 对 象 中 的 $cache lifetime 属性 , 缓存 时 间 以 秒 为 单位 , 默认 值 是 3600 秒 , 其 操作 代码 如 下 : 


$smarty->caching=true: /开启 缓存 
$smarty->cache_dir=BASE PATH .SMARTY PATH.'cache/; /定义 缓存 文件 存储 位 置 
$smarty->cache lifetime=3600 /设置 缓存 时 间 为 1 小 时 


(3) 判断 模板 文件 是 否 已 经 被 缓存 。 
如 果 页 面 已 经 被 缓存， 那么 就 可 以 直接 调用 缓存 文件 ， 而 不 再 执行 动态 获取 数据 和 输出 的 操作 。 为 了 避免 
在 开启 缓存 后 ， 再 次 执行 动态 获取 数据 和 输出 操作 给 服务 器 带 来 的 压力 ， 最 佳 的 方法 就 是 应 用 Smarty 对 象 中 的 
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is_cached( 方 法 ， 判 断 指 定 的 模板 是 否 存在 缓存 ， 如 果 存 在 ， 则 直接 执行 缓存 中 的 文件 ， 否 则 执行 动态 获取 数据 


和 输出 的 操作 。 操 作 代码 如 下 : 


$smarty->cachine=true; 
if(!$smarty->is_cached('index.html)){ 
// 执 行动 态 获取 数据 和 输出 的 操作 
} 
$smarty->display(index.html); 
(4) 清除 模板 中 缓存 。 
缓存 的 清除 有 两 种 方法 : 


/开启 缓存 


@ clear all cache( 方 法 ， 清 除 所 有 模板 缓存 ， 其 语法 如 下 : 


void clear all cache (int expire time) 


可 选 参数 expire time， 可 以 指定 一 个 以 秒 为 单位 的 最 小 时 间 ， 超 过 这 个 时 间 的 缓存 都 将 被 清除 。 

@) clear_cache0 方 法 ， 清 除 指定 模板 的 缓存 ， 其 语法 如 下 : 

void clear_cache (string template [, string cache id [, string compile id [, int expire time]]]) 

如 果 这 个 模板 有 多 个 缓存 ， 可 以 用 第 2 个 参数 指定 要 清除 缓存 的 缓存 号 ， 还 可 以 通过 第 3 个 参数 指定 编译 
号 。 可 以 把 模板 分 组 ， 以 便 方便 地 清除 一 组 缓存 。 第 4 个 参数 是 可 选 的 ， 用 来 指定 超过 某 一 时 间 ( 以 秒 为 单位 》 


的 缓存 才 会 被 清除 。 


图 设计 过 程 


这 里 在 实例 567 的 基础 上 ， 完 成 用 户 注册 的 功能 ， 并 且 开启 用 户 注册 页 面 的 缓存 。 有 关 缓 存 的 设置 在 


index.php 动态 页 中 完成 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); 


require_once(" system/system.ine.php"); 


VSsmarty->clear_all cacheO; 
这 !$smarty->is cached(index.html)){ 
Sres=$conn->execute(" | bccd "); 


for(Si=0:$i<Sres- ec dounil: SIE 
Sarray_id[]=$array{$i][id]: 
a name[]=S$array[$ilfnamel; 


Ssmarty->assign('cust_id', $array_id); 
Ssmarty->assign('cust_name’, $array_name); 
} 

Sarray= explode(' '. mt_rand(1000.9999)): 


$smarty->assign('title', 开 启 网 站 注册 页 面 的 缓存 ); 


S$smarty->assign('content’ $array); 
$smarty->assign('contents'. $arrays); 
Ssmarty->display('index.html); 

> 


/设置 文件 编码 格式 
/包含 配置 文件 
/开启 缓存 
/设置 缓存 过 期 时 间 
/清除 所 有 缓存 


/| 执行 select 查询 语句 


// 设 置 下 拉 列 表 的 值 
/设置 列表 的 显示 数据 


/生成 随机 验证 码 

// 将 指定 数据 赋 给 模板 变量 
// 将 数组 赋 给 模板 变量 

// 将 数组 赋 给 模板 变量 
/指定 模板 页 


缓存 文件 存储 在 system\Smarty\cache 目录 下 , 而 存储 路 径 的 设置 是 在 system\system.smarty.inc.php 文件 中 完 
成 的 。 有关 用 户 注册 的 其 他 功能 ， 请 读者 参考 实例 567， 这 里 不 再 次 述 。 


图 秘笈 心 法 


心 法 领悟 580: 同一 模板 生成 多 个 缓存 。 


在 实际 的 程序 开发 中 ， 经 常会 遇 到 同一 个 模板 文件 生成 多 个 页 面 的 情况 。 此 时 要 对 这 多 个 页 面 进行 缓存 ， 
就 要 应 用 Smarty 中 的 display0 方 法 ， 通 过 该 方法 的 第 2 个 参数 设置 缓存 号 ， 有 几 个 不 同 的 缓存 号 就 有 几 个 缓存 


页 面 ， 操 作 代码 如 下 : 
Ssmarty->cachi 


->caching=true; 
Ssmarty->cache dir=BASE PATH.SMARTY PATH.'cache/; 
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/开启 缓存 
/定义 缓存 文件 存储 位 置 


第 14 章 Smarty 模板 
Ssmarty->cache lifetime=3600; // 设 置 缓存 时 间 为 1 小 时 
Ssmarty->display(index.html'.$_GET['id']): // 将 记 作 为 第 2 个 参数 传递 
人 
高 级 | 
趣味 指数 : 请 福全 闪 | 


实例 说 明 
配置 文件 的 应 用 ， 有 利于 设计 者 管理 文件 中 的 模板 全 局 变量 。 例 如 ， 定 义 一 个 模板 色彩 变量 ， 一 般 情况 下 
如 果 想 改变 一 个 程序 的 外 观 色 彩 ， 必 须 更 改 每 一 个 文件 的 颜色 变量 。 如 果 有 配置 文件 ， 色 彩 变 量 就 可 以 保存 在 
-个 单独 的 文件 中 , 只 要 改变 配置 文件 就 可 以 实现 色彩 的 更 新 , 这 与 在 Web 页 面 开 发 中 应 用 的 CSS 样式 非常 相 
似 。 在 本 实例 中 ， 将 讲解 如 何 应 用 Smarty 中 的 配置 文件 ， 并 通过 配置 文件 定义 页 面 中 body 标签 的 样式 ， 其 运 
行 结果 如 图 14.33 所 示 。 


钼 免费 服务 热线 -400-675-1066 税收 训 本 站。 网 设 为 首页 岛 联系 我 们 
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明日 编程 词典 


http://www mrbccdcom 


回 。 编程 词 奥 软 件 
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图 14.33 通过 配置 文件 定义 页 面 的 样式 

图 关键 技术 

(1) 创建 配置 文件 。 

配置 文件 可 以 任意 命名 ， 其 存储 位 置 由 Smarty 对 象 的 $config_dir 属性 指定 。 如 果 存 在 不 只 在 一 个 区 域内 使 
用 的 变量 值 ， 可 以 使 用 三 引号 〈""") 将 其 完整 地 封装 起 来 。 在 创建 配置 文件 时 ， 建 议 在 程序 运行 前 使 用 “#” 
加 一 些 注释 信息 ， 这 样 有 助 于 程序 的 阅读 、 更 新 。 

在 配置 文件 中 既 可 以 声明 全 局 变量 ， 也 可 以 声明 局 部 变量 。 如 果 声 明 局 部 变量 ,可 以 使 用 中 括号 “[]” 括 起 
来 ， 在 中 括号 之 内 声明 的 变量 属于 局 部 变量 ， 而 中 括号 之 外 声明 的 变量 都 是 全 局 变量 。 中 括号 的 使 用 不 仅 使 配 
置 文件 中 声明 变量 的 模块 变 得 清晰 ， 而 且 可 以 在 模板 中 选择 加 载 中 括号 内 的 变量 。 

(2) 加 载 配置 文件 。 


加 载 配置 文件 应 用 Smarty 的 内 建 函 数 config load， 其 语法 如 下 : 
{config load file="file name " section="add_attribute" scope="" global=""} 


参数 说 明 : 

file: 指定 包含 的 配置 文件 的 名 称 。 

section: 附加 属性 ， 当 配置 文件 中 包含 多 个 部 分 时 应 用 ， 指 定 具 体 从 哪 一 部 分 中 取得 变量 。 

scope: 加 载 数据 的 作用 域 , 取 值 必须 为 local、 parent 或 global。 local 说 明 该 变量 的 作用 域 为 当前 模板 ; parent 
说 明 该 变量 的 作用 域 为 当前 模板 和 当前 模板 的 父 模板 (调用 当前 模板 的 模板 ); global 说 明 该 变量 的 作用 域 为 
所 有 模板 。 
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PHP 开发 实战 1200 例 (第 I 卷 ) 
global: 说 明 加 载 的 变量 是 否 全 局 可 见 ， 等 同 于 scope=parent。 
阁 提示 : 当 指 定 scope 属性 时 ， 可 以 设置 global 属性 ， 但 模板 忽略 该 属性 值 ， 而 以 scope 属性 为 准 。 


(3) 引用 配置 文件 中 的 变量 。 

配置 文件 加 载 成 功 后 , 就 可 以 在 模板 中 引用 配置 文件 中 声明 的 变量 . 引用 配置 文件 应 用 的 是 “#” 或 者 Smarty 
的 保留 变量 $smarty.config， 其 应 用 示例 如 下 : 

{ config load file="file con.conf"} {* 加 载 配置 文件 *} 

ti 

es colspan="2" align="left" valign="top" class=" {$smarty.config.styles}"> 
图 设计 过 程 

(1) 创建 system 文件 来， 定义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 在 目 录 和 配置 文件 目录 ; 创建 类 文件 
system.smarty.inc.php， 定 义 Smarty 的 配置 类 ， 在 该 类 中 指定 配置 文件 存储 的 目录 ， 定 义 类 的 实例 化 文件 
system.inc.php， 完 成 Smarty 类 的 实例 化 操作 ， 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 通 过 文件 系统 函数 file_get_ contents0 读 取 文 本 文件 中 的 
数据 ， 并 且 将 数据 存储 到 模板 变量 中 ， 最 终 指 定 模板 页 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
include("system/system.inc.php"); // 包 含 配 置 文 件 

$str = file_get_contents('files/content.txt"); /1/ 读 取 文 本 文件 中 的 数据 
Ssmarty->assign('content ,iconv("gb2312","utf-8",$str)); // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
Ssmarty->display('index.html’); /| 指定 模板 页 

> 


(3) 创建 index.html 模板 页 。 首先 , 通过 config load0 函 数 加 载 配置 文件 。 然后 , 应 用 “#” 和 $smarty.config 
引用 配置 文件 中 的 变量 。 最 后 ， 通 过 模板 变量 输出 文本 文件 中 的 数据 ， 其 关键 代码 如 下 : 
{config_load file="file_con.conf"} {* 加 载 配 置 文件 *} 
<title> {#title#} </title> 
<body leftmargin=" {#leftmargin#}" topmargin=" {#topmargin#}" marginwidth=" {#marginwidth#}" marginheight=" {#marginheight#}"> 
<td height="228" colspan="2" align="left" valign="top" class=" {$smarty.config.styles}">{$content}</td> 


图 秘笈 心 法 

心 法 领悟 581: Smarty 模板 的 最 佳 配 置 方案 。 

答案 就 在 本 章 的 实例 中 ， 应 用 面向 对 象 技 术 ， 将 配置 方法 封装 到 类 中 ， 应 用 Smary 模板 时 调用 类 的 实例 化 
文件 即 可 。 通 过 这 种 方法 配置 Smarty 模板 ， 不 必 再 设置 服务 器 的 绝对 路 径 和 Smarty 类 库 的 绝对 路 径 ， 非 常 简 
单 、 方 便 。 


814 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


RE 


综合 应 用 


MW PHP 页 面 编 码 

WI 网 站 公共 文件 设计 
WI 注册、 登录 

WI 数据 的 输出 

WI 站 内 搜索 

MW 高 级 搜索 
”购物 车 

”图 书 订 单 处 理 

让 “后 台 管 理 系统 登录 
MW 系统 管理 

WI 图 书 类 别管 理 

让 图书 管理 

让 ”用户 管理 
”订单 信息 管理 

| 通用 信息 管理 


PHP 文件 的 页 面 编码 是 指 文件 以 何 种 形式 保存 , 其 中 支持 简体 中 文 的 编码 主要 有 GB2312、GBK 和 utf-8 等 ， 
本 节 将 对 PHP 常用 的 页 面 编码 格式 和 PHP 的 国际 化 通过 具体 实例 进行 讲解 。 


趣味 指数 : 二 走 二 
图 实例 说 明 _ 


本 实例 主要 讲解 如 何 设置 页 面 编码 格式 为 GB2312 编码 ， 运 行 本 实例 ， 如 图 15.1 所 示 ， 在 页 面 中 打印 出 明 
日 企业 网 的 页 面 编码 的 提示 信息 ， 从 运行 结果 可 以 知道 该 页 面 所 使 用 的 编码 为 GB2312 编码 。 


人 明 串 十 业 网 


/www mr bcc ,ca 


这 是 一 人 032512 闹 玫 式 的 页 面 


图 15.1 打印 明日 企业 网 的 页 面 编码 


图 关键 技术 


设计 GB2312 编码 格式 的 网 页 需要 进行 两 点 设置 ， 首 先 使 用 编辑 器 设置 页 面 文 件 的 编码 为 GB2312 格式 ， 
然后 通过 HTML 语言 的 meta 标记 或 PHP 的 header0 函 数 设置 页 面 编码 为 GB2312。 

设置 页 面 文件 编码 可 以 使 用 UltraEdit、Edit Plus 和 Zend Studio 等 编辑 器 。 下 面 将 以 Zend Studio 为 例 讲解 
如 何 设置 页 面 文 件 编码 。 

打开 Zend Studio 后 ， 选 择 要 设置 编码 的 文件 ， 然 后 单 击 右 键 ， 将 弹出 如 图 15.2 所 示 的 页 面 ， 选 择 “ 属 性 ” 
选项 ， 将 弹出 如 图 15.3 所 示 的 页 面 属 性 对 话 框 。 

在 页 面 属性 对 话 框 中 选择 文件 编码 模块 ,在 该 模块 的 其 他 编码 的 下 拉 列 表 框 中 选择 GBK 编码 ,然后 单 击 “ 应 
用 ”按钮 ， 最 后 单 击 “ 确 定 ” 按 钮 即 可 完成 对 页 面 文件 编码 的 设置 。 


[RAT 时间 
pe。 635 brees 
Lct podified: 2010 年 3 月 17 日 下 午 04:2002 


图 15.2 页面 常规 操作 下 拉 列 表 图 15.3 页 面 属性 对 话 框 
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说 明 : 在 文件 编码 下 拉 列 表 中 并 没有 GB2312 编码 ， 而 GBK 编码 包含 简体 中 文 编码 ， 所 以 这 里 选择 GBK 
编码 。 


完成 对 页 面 文件 的 编码 设置 后 ， 还 需要 使 用 meta 标记 设置 页 面 编 码 ， 其 设置 方法 如 下 : 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
图 设计 过 程 
(1) 创建 index.php 页 面 , 并 设置 页 面 文件 的 编码 为 GB2312, 其 具体 设置 方法 已 经 在 关键 技术 中 进行 讲解 ， 
这 里 不 再 袭 述 。 
(2) 在 index.php 文件 中 通过 HTML 语言 的 meta 标记 设置 网 页 编码 为 GB2312 格式 ， 具 体 实现 代码 如 下 : 
<!DOCTYPE html PUBLIC "-/W3C//DTD XHTML 1.0 Transitional/EN" "http://www.w3.0rg/TR/xhtmll/DTD/xhtml1-transitional.dtd"> 
<html xmins="http://www.w3.org/1999/xhtml"> 
<head> 
<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 


<br> 
<div style= "width: 487px; text-align:center; height:221px: line-height:221px; font-size: 16px; color:blue; background:url(img/bg.jpg)"> 
这 是 一 个 GB2312 编码 格式 的 页 面 
</div> 
</body> 
</html> 


图 秘笈 心 法 

心 法 领悟 582: 在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 。 

在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 。 首 先 ， 打开 Dreamweaver 开发 工具 ， 单 击 “ 编 辑 ” 按 钮 ， 
选择 “首选 参数 ”命令 ， 在 弹出 的 “首选 参数 ”对 话 框 中 通过 “默认 编码 ”下 拉 列 表 框 设置 创建 文件 的 编码 格 
式 ， 如 图 15.4 所 示 ， 设 置 完成 后 单 击 “ 确 定 ” 按 钮 。 


ET 可 


.3 - 
ER - 
二 
太 当 打开 不拘 定 往 码 的 秽 有 文件 对 货 月 
[| 
厂 包括 Uaicods 答 名 GO G) 


厄 控 Central 姐 台 钥 时 旦 示 “ 萌 建 廊 尖 "对调 恬 0D) 


CJ] ww | 邮 


力 实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编码 格式 为 GBK。 运行 本 实例 ， 如 图 15.5 所 示 , 在 页 面 中 打印 出 咖啡 
小 屋 程序 所 使 用 的 页 面 编码 。 
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这 是 一 个 GBF 编码 格式 的 页 面 


15.5 打印 咖啡 小 屋 的 页 面 编码 


图 关键 技术 
本 实例 的 关键 技术 是 设置 网 页 的 页 面 编码 格式 为 GBK， 同 样 其 设置 方法 也 包括 两 个 部 分 。 首 先 设置 网 页 文 
件 的 编码 为 GBK 格式 ， 其 设置 方法 与 实例 582 相同 ， 这 里 不 再 袭 述 。 然 后 使 用 HTML 语言 的 meta 标记 设置 网 
页 的 编码 为 GBK， 其 设 定 代码 如 下 : 
<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
图 设计 过 程 
(1) 创建 index.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 GBK。 
(2) 在 index.php 文件 中 使 用 meta 标记 设置 网 页 编码 格式 为 GBK， 并 在 页 面 中 打印 当前 页 面 所 使 用 的 编 
码 ， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtml1-transitional.dtd"> 
<html xmins="http://www.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<br> 
<div style="width: 498px: text-align:center; height:332px; line-height221px: font-size:16px: color:#FF3300: backgroundurllimgbgjpg)"> 
这 是 一 个 GBK 编码 格式 的 页 面 
</div> 


<html> 
图 秘笈 心 法 


心 法 领悟 583: GB2312 和 GBK。 
GB2312 和 GBK 是 中 国政 府 颁布 的 标准 汉字 编码 。GB2312 编码 中 放置 了 6763 个 常用 汉字 ， 并 且 首 次 在 中 
文 操作 系统 CCDOS 中 使 用 ，GBK 编码 在 GB2312 编码 的 基础 上 ， 增 加 了 我 国 台湾 BIG5 编码 中 的 15000 多 个 


汉字 的 字符 。 


中 级 
趣味 指数 : 会 傅 痉 | 


力 实例 说 明 


本 实例 主要 讲解 如 何 设 置 网 页 页 面 编码 格式 为 UTF-8。 运 行 本 实例 ， 如 图 15.6 所 示 ， 将 在 页 面 中 打印 出 企 
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业 邮 局 收发 系统 所 使 用 的 页 面 编码 。 


收 沂 箱 /发 避 箱 
上 


3 区 时 条 


这 是 一 个 UTF-8 编 码 格 式 的 页 面 


15.6 打印 企业 邮局 收发 系统 页 面 编 码 


图 关键 技术 


UTF 是 国际 字符 集 转换 格式 (Unicode/UCS Transformation Format) 的 缩写 ， 是 FCS 的 实际 表达 式 ， 按 其 基 
本 长 度 所 用 位 数 分 为 UTF-8/16/32 这 3 种 形式 ， 其 中 UTF-8 保持 字符 数字 一 个 字 节 ， 其 他 的 用 不 定 长 编码 到 最 
多 6 个 字 节 ， 支 持 到 31 位 编码 。UTEF 中 最 常用 的 就 是 UTF-8 编码 格式 ，UTF-8 使 用 8 位 字 节 编码 ， 通常 使 用 1 
到 3 位 字 节 来 表示 一 个 字符 ， 字 符 的 编码 长 度 为 变 长 。 
UTF-8 字符 集 不 仅 包 括 欧 美 字符 ， 也 包括 中 国 、 日 本 和 韩国 的 全 角 字符 。 因 此 ， 在 网 页 中 使 用 UTF-8 字符 
集 可 以 使 用 户 在 不 安装 中 文 编码 的 情况 下 浏览 到 大 部 分 中 文字 符 。 
本 实例 设置 页 面 为 UTF-8 编码 ， 首 先 需 要 使 用 编辑 工具 设置 页 面 文件 编码 格式 为 UTF-8， 然 后 使 用 HTML 
的 meta 标记 设置 网 页 编码 格式 为 UTF-8， 其 设置 方法 如 下 : 
<meta http-equiv="content-type” content="text/html; charset=utf-8" /> 
力 设计 过 程 
(1) 新 建 index.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 UTF-8。 
(2) 在 HIML 语言 的 meta 标记 中 设 定 当前 页 面 所 使 用 的 编码 格式 为 UTF-8， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional/EN" "http://www.w3.o0rg/TR/xhtmll/DTD/xhtmll-transitional.dtd"> 
<html xmins="http://www.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 UTF-8 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 

</head> 

<body> 
<br> 
<div style= "width: 978px: text-align:center: height:591px: line-height:591px: font-size:16px: color:#09600C: background:url(img/bg.jpg)"> 

这 是 一 个 UTF-8 编码 格式 的 页 面 

<div> 

‘</body> 

</html> 


力 秘笈 心 法 

心 法 领悟 584: Web 程序 开发 中 页 面 编码 格式 的 选择 。 

为 了 便于 程序 的 国际 化 及 使 程序 支持 更 多 语言 版 本 的 操作 系统 ， 在 项 目 开发 中 建议 将 页 面 设置 为 UTF-8 编 
码 格式 。 


i 
中 级 
| 超 味 指数 : 从 丰 页 


图 实例 说 明 

信息 全 球 化 的 高 速 发 展 ， 使 企业 的 市 场 也 在 逐步 扩大 ， 并 逐渐 走向 世界 。 企 业 向 世界 展示 自己 ， 必 不 可 少 
地 要 应 用 到 互联 网 ， 在 应 用 互联 网 的 过 程 中 必须 要 提供 多 国语 言 的 支持 。 只 有 这 样 才能 让 更 多 的 人 了 解 企 业 。 
所 以 在 开发 程序 的 过 程 中 ， 必 须要 提供 对 多 国语 言 的 支持 。 本 实例 以 一 个 简单 的 企业 内 部 管理 系统 为 例 ， 介 绍 


如 何 通过 PHP 语言 开发 提供 多 国语 言 支持 的 程序 。 在 实例 中 ， 实 现 文章 的 添加 和 浏览 功能 ， 并 且 提 供 对 中 文 和 
英文 两 种 语言 的 支持 。 中 文 文章 添加 页 面 如 图 15.7 所 示 ， 英 文 文章 添加 页 面 如 图 15.8 所 示 。 
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图 15.7 中文 文章 添加 页 面 图 15.8 英文 文章 添加 页 面 

图 关键 技术 


本 实例 中 应 用 到 的 关键 技术 如 下 : 
(1) 网 页 编码 的 设置 。 


在 网 页 中 ， 字 符 编码 通过 <head> 标 签 中 <meta> 标 签 的 charset 属性 来 设置 。 设 置 网 页 编码 的 代码 如 下 : 
<html xmlns="http://www.wW3.org/1999/xhtml"> 

<meta http-equiv="Content-Type" content="text/html:; charset=gb2312" /> 
<title> 设 置 网 页 编码 格式 </title> 


</head> 
<body> 通 过 meta 标签 的 charset 属性 设置 字符 编码 格式 </body> 
</html 
(2) 获取 客户 端 语言 选项 ， 根 据 语言 选项 的 值 调 用 不 同 的 语言 配置 文件 。 


$_SERVER['HTTP_ACCEPT_LANGUAGE'] 为 服务 器 变量 ， 用 于 获取 客户 端 浏览 器 的 语言 设置 。 
本 实例 中 ， 获 取 语 言 选项 和 调用 不 同 语言 配置 文件 的 代码 如 下 : 
<2php 


session start(); 
Slang=$_SERVER[HTTP_ACCEPT LANGUAGE': /获取 语言 选项 
S$lang-explode(:'Slang): /以 “;” 对 字符 串 进行 分 隔 
$lang=$lang[0]: /为 数组 赋值 
$lang=explode(,,Slang): /以 “,” 对 字符 串 进行 分 隔 
Slang=$lang[0]:; /为 数组 赋值 
switch(Slang){ /根据 获取 到 的 语言 选项 的 值 ， 为 变量 赋值 
case "en-us": 

Slang—"en” 
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} 
iflisset($ SESSIONTlangTD)f 
Slang=$_SESSION['lang’]: // 为 SESSION 变量 赋值 
} 
include "lang/lang_Slang.php"; // 调 用 不 同 的 语言 配置 文件 
> 


图 设计 过 程 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 数据 库 的 连接 ， 其 代码 如 下 : 
ee 1") or die( 连 接 失败 :' . mysql_error0); 
mysql_select_db("db_database15",Sconn) or die (数据 库 选择 失败 :' . mysql_error0); 
mysql_query("set names gb2312"); 
?> 
(2) 创建 lang 文件 夹 , 编写 lang_ch.php 和 lang_en.php 文件 , 分 别 定义 中 文 语言 配置 和 英文 语言 配置 文件 ， 
代码 请 参考 附送 光盘 中 的 内 容 。 
(3) 创建 config.php 文件 ， 获 取 浏 览 器 中 语言 选项 的 值 ， 根 据 语言 选项 的 值 调用 不 同 的 语言 配置 文件 。 其 
完整 代码 可 以 参考 关键 技术 中 的 内 容 。 
(4) 创建 setlang.php 文件 ， 根 据 超 链 接 中 传递 的 参数 ， 为 SESSION 变量 赋值 ， 并 且 调 用 不 同 的 操作 页 面 ， 
其 代码 如 下 : 
<?php 
session_start(); 
switch($_GET['lang ]){ // 获 取 超 链接 传递 的 语言 选项 的 值 
By er // 根 据 超 链接 的 值 ， 为 SESSION 变量 赋值 
Case ee 
$ SESSIONT'lang'"]="ch"; 
break; 
default : 
$ SESSIONT lang'l="en"; 
break:; 


ei i // 恨 据 超 链接 的 值 ， 跳 转 到 不 同 操作 页 面 
header("Location:addnew.php"); 

jelseif ($_GET[link]=—"show"){ 

a header("Location:show.php"); 

， header("Location:index.php"): 

> 

(5) 创建 ndex.php 文件 ， 根 据 选 择 的 语言 不 同 ， 输 出 不 同 的 页 面 和 内 容 。 首 先 ， 通 过 require_onceO 语 句 

调用 不 同 的 包含 文件 ， 完 成 数据 库 连 接 和 语言 配置 。 然 后 ， 执 行 查询 操作 ， 从 数据 表 中 读 取 指定 的 数据 信息 。 
最 后 ， 在 页 面 中 输出 数据 ， 其 关键 代码 如 下 : 


<?php 

Tequire_once('conn/conn.php’): // 连 接 数 据 库 
Tequire_once('config.php’): // 调 用 语言 配置 文件 
$query_rs="select * from tb_articles where langver='$rs_filter’ order by id desc": // 定 义 查询 语句 
S$rs=mysql_query(Squery_rs.Sconn) or die(mysql_errorO): /执行 查询 操作 
Srow_Is=mysql fetch_assoc($rs): /获取 查询 结果 的 记录 数 
> 


ee 创建 add_data.php 文件 ， 添 加 from 表单 ， 用 于 提交 数据 ， 并 完成 对 表单 中 数据 处 理 的 操作 。 首 先 ， 
通过 require_once0 语 句 调用 不 同 的 包含 文件 , 完成 数据 库 连 接 和 语言 配置 。 然后 , 定义 方法 GetSQLValueStringO 
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完成 对 数据 格式 的 转换 。 接 着 ， 获 取 表 单 中 提交 的 数据 ， 并 应 用 sprintf0) 函 数 和 GetSQLValueString0 方 法 完成 对 
数据 格式 的 转换 ， 将 数据 添加 到 数据 表 中 。 最 后 ， 设 计 文 章 添加 页 面 ， 创 建 form 表单 ， 完 成 数据 的 提交 操作 ， 
其 关键 代码 如 下 : 

<?php 


Tequire_once(' conn /conn.php"); // 连 接 数 据 库 
Tequire_once('config.php’); /配置 语言 
/定义 格式 转换 的 方法 


function GetSQLValueString($theValue.$theType. S$theDefinedValue="", $theNotDefinedValue=""){ 
StheValue=(!get_magic_quotes gpcO) ? addslashes(StheValuej:StheValue: 
switch(StheType){ 
Case "text"; 
StheValue=($theValue !="")? "". $theValue. ™™ : "NULL"; 
break; 


|: 
Tetum $theValue: 


} 

这 $ POSTI"Submit"]—TRUE){ 

/获取 表单 中 提交 的 数据 ， 并 完成 对 数据 格式 的 转换 

SinsertSQL=sprintf("insert into tb_articles(topic.author,comefrom.content,langver) Values(96s.96s,96s.96s.90S)”， 
GetSQLValueString($_POST['topic'], "text"), 
GetSQLValueString($ POST['author],"text"), 
GetSQLValueString($_POST['comefron?'],"text"), 
GetSQLValueString($_POST['content]. "text"). 
GetSQLValueString($ POST[langver],"text") 
); 

/执行 添加 语句 ， 将 数据 添加 到 数据 表 中 

SResultl=mysql query($insertSQL.Sconn) or die(mysql eror0); 

echo "<script>alert('$add_data_Suc’); window.location.href='add_data.php':</script>"; 

} 


> 

(7) 创建 look_overphp 文件 ， 根 据 超 链接 传递 的 ID 值 ， 执 行 查询 操作 ， 输 出 指定 文章 的 详细 信息 ， 代 码 
请 参考 光盘 中 内 容 。 
力 秘笈 心 法 

心 法 领悟 585， 设 置 数据 库 中 数据 输出 的 编码 格式 。 

设置 数据 库 中 数据 输出 的 编码 格式 在 connphp 文件 中 进行 ， 通 过 mysql_query0 函 数 完成 ， 本 实例 中 设置 的 
是 gb2312 编码 格式 。 切 记 ， 这 里 设置 的 编码 格式 必须 与 数据 库 中 字段 的 编码 格式 相同 ， 否 则 在 输出 数据 库 中 数 
据 时 将 出 现 乱 码 。 

如 果 没有 在 conn.php 文件 中 进行 数据 库 编码 格式 的 设置 ， 在 输出 数据 库 中 的 数据 时 ， 如 果 页 面 编码 格式 与 
数据 库 中 字段 设置 的 编码 格式 不 同 ， 那 么 在 输出 中 文字 符 串 时 有 可 能 出 现 乱码 。 


15.2 ”网 站 公共 文件 设计 


在 进行 项 目 开 发 时 ， 为 提高 代码 的 重用 率 及 方便 系统 维护 ， 经 常 需要 将 Web 程序 中 的 共性 功能 进行 封装 ， 
本 节 将 通过 具体 实例 讲解 网 站 公共 文件 的 设计 方法 和 具体 应 用 。 


中 级 | 
趣味 指数 : 信人 帘 耸 | 

图 实例 说 明 
明日 科技 书店 网 站 的 数据 库 管 理 采 用 ADODB 数据 库 抽 和 象 层 技术 ， 使 用 ADODB 技术 连接 数据 库 ， 可 以 实 
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/通过 Connect0 方 法 建立 与 数据 库 的 连接 
if (Sthis->dbType 一 mysql) { 
S$this->connID->Execute('set names gb2312): // 设 置 数据 库 编码 
} elseif (Sthis->dbType — 'access) { // 如 果 为 Access 数据 库 


Sthis->connID->Connect(Driver = {Microsoft Access Driver (*.mdb)}; Dbq = . realpath($this->dbName) . “Uid =". $this->userName . "Pwd 
=". $this->password . "); 


}else{ 
Tetum false: 
} 
S$this->connID->debug = Sthis->isDebug: /是 否 调 试 
Teturn $this->connID; // 返 回 数据 库 连 接 对 象 


} 

上 述 代码 首先 使 用 require_once0 函 数 包含 ADODB 中 的 adodb.inc.php 文件 , 这 样 就 实现 了 将 ADODB 类 库 
包含 到 工程 中 ， 然 后 根据 属性 $dbType 的 值 判断 要 连接 数据 库 的 类 型 ， 根 据 不 同 的 数据 库 类 型 选择 不 同 的 连接 
方式 ， 最 后 通过 retum 语句 返回 数据 库 连接 对 象 。 在 进一步 开发 中 ， 只 需 通过 该 方法 返回 的 数据 库 连 接 对 象 来 
调用 相应 的 方法 〈 如 Execute0 方 法 ) 即 可 实现 对 数据 库 的 查询 。 

(4) 完成 对 数据 库 的 操作 后 ， 还 需要 关闭 对 数据 库 的 连接 ， 这 里 通过 closeConnID0 方 法 实现 ， 其 代码 如 下 : 

function closeConnID O{ 

@$this->connID->DisconnectO; /关闭 与 数据 库 的 连接 

以 上 为 数据 库 连 接 类 ConnDB 的 全 部 核心 内 容 ， 主 要 实现 对 不 同类 型 数据 库 的 连接 及 在 操作 完 数据 库 后 释 

放 资 源 等 操作 。 


图 设计 过 程 
(1) 建立 数据 库 连接 类 ConnDB， 其 具体 实现 代码 已 经 在 关键 技术 中 进行 讲解 ， 这 里 不 再 效 述 。 
(2) 在 lzhConfig ini 文件 中 配置 各 项 数据 库 连 接 参数 的 值 ， 具 体 配置 代码 如 下 : 


UserName = root 


(3) 对 ConnDB 类 进行 实例 化 ， 并 使 用 实例 化 后 的 对 象 调用 类 中 的 getConnID0 方 法 返回 数据 库 连 接 标 识 ， 
从 而 实现 与 数据 库 的 连接 ， 代 码 如 下 : 


$connDB = new ConnDB($arrayIni['dbType'] ,SarrayIni[host] ,$arrayIni['userName’] .SarrayIni[password'] .SarrayIni['dbName'] ,SarrayIni[isDebug]); 
$connID = $connDB->getConnIDO: 


力 秘笈 心 法 


心 法 领悟 586: 屏蔽 程序 中 的 运行 错误 。 
在 开发 PHP 项 目 时 ， 可 以 通过 在 语句 前 加 “@” 符 号 来 屏蔽 运行 时 的 错误 。 


图 实例 说 明 

为 了 对 项 目 中 的 SQL 语句 进行 统一 管理 ， 提 高 代码 重用 率 和 项 目的 可 维护 性 ， 本 实例 将 数据 库 的 增 、 删 、 
改 、 查 操作 通过 专门 的 数据 库 管理 类 实现 ， 在 明日 科技 书店 网 站 获取 图 书 内 容 简介 就 是 使 用 该 类 实现 的 ， 其 运 
行 效 果 如 图 15.10 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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之 所 以 要 在 数据 库 管理 类 中 提取 SQL 语句 的 前 6 个 字符 ， 是 利用 select、update 和 delete 关键 字 的 字符 长 
度 都 是 6 个 字 节 的 特点 ， 通 过 截取 的 6 个 字 节 可 以 判断 出 SQL 语句 的 类 型 。 


综合 应 用 


图 实例 说 明 


为 了 有 效 地 利用 页 面 资源 ， 设 计 出 合理 的 页 面 布局 ， 在 制作 明日 科技 书店 的 图 书信 息 展示 模块 时 ， 采 用 分 


页 的 方式 ， 明 日 科技 书店 的 新 书 分 页 展示 模块 如 图 15.11 所 示 。 


让 当前 的 位 置 ， 明日 隐 上 书记 > 新书 接 在 
新 书 堆 失 7 本 每 页 显示 t0 本 第 1 页 / 共 1 页 
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图 关键 技术 
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图 书 分 页 展示 


如 果 每 个 图 书信 息 展示 模块 都 编写 类 似 的 代码 实现 分 页 ， 不 仅 会 降低 开发 效率 ， 还 为 生产 环境 下 的 维护 带 
来 很 大 负担 ， 为 解决 上 述 问题 ， 将 图 书 的 分 页 功能 封装 成 分 页 类 ， 只 需 在 需要 使 用 分 页 展示 图 书信 息 的 页 面 调 
用 该 类 的 相应 方法 即 可 。 下 面 介绍 分 页 类 的 实现 方法 ， 其 代码 如 下 : 


class PageDB{ 
function pageData ($sql. $connID, SpageSize, Spage){ 
SarrayPageInfo = arrayO; 
SnowPage = $page: 
Srs = $connID->PageExecute($sql $pageSize, SnowPage): 
SarrayData = $rs->GetRows0: 
if (count(SarayData) — 0 || Srs 一 false) { 
Teturn false; 
else { 
SarrayPageInfo['data’] = SarrayData: 
S$rsAll = $connID->Execute($sql); 
$countRs = count($rsAll->GetRowsO): 
ScountPage = ceil(ScountRs / SpageSize): 
SarrayPageInfo[pageSize] = SpageSize: 
SarrayPageInfo['countRs'] = $countRs: 
SarrayPageInfo['page'] = SnowPage: 


/用 于 保存 分 页 信息 的 数组 

// 当 前 页 码 

// 通 过 ADODB 的 PageExecute0 方 法 获得 指定 页 码 的 记录 集 
// 将 结果 保存 到 数组 中 

// 如 果 没有 查询 到 内 容 ， 则 返回 FALSE 


// 每 页 的 数据 


/| 每 页 显示 记录 的 条 数 
/总 记录 数 
// 当 前 页 


PHP 开发 实战 1200 例 (第 I 卷 ) 


SarrayPageInfo['countPage] = $countPage; // 总 页 数 
SarrayPageInfo['first] = 1: // 第 一 页 的 页 码 
if(Spage> 1) { 

SarrayPageInfo[previous'] = $rs->AbsolutePage() - 1:; // 前 一 页 的 页 码 
Yelse{ 


S$arrayPageInfo[previous]= 1; 


if (S$page < $countPage) { 


SarrayPageInfo['next] = $rs->AbsolutePage| + 1 /后 一 页 的 页 码 
| = $countPage; 
SarrayPageInfo['last] = $countPage; /最 后 一 页 的 页 码 
ee SarrayPageInfo; 


} 


} 
I 设法 使 用 ADODB 数据 抽象 层 获 取 指 定 页 码 中 所 显示 的 数据 ， 同 时 将 首页 、 上 
页、 下 一 页 、 尾 页 、 总 页 码 和 总 记录 数 都 作为 数组 元 素 ， 然 后 将 该 数组 作为 分 页 类 中 实现 分 页 方法 的 返回 值 
加， We 分 页 的 模块 ， 只 需要 通过 分 页 类 获取 该 返回 数组 就 可 以 获得 所 有 分 页 所 需 信息 
在 实现 上 述 PageDB 分 页 类 时 ,在 类 体内 只 定义 一 个 pageData0 分 页 方法 ,在 该 方法 内 部 , 通过 ADODB 数 
据 抽象 层 根据 分 页 方法 的 $pageSize 和 $page 参数 获取 页 面 显示 的 数据 和 分 页 导航 参数 ， 并 保存 到 $arrayPageInfo 
数组 中 返回 。 
图 设计 过 程 

(1) 建立 数据 库 分 页 类 PageDB， 并 在 该 类 中 建立 pageData0 方 法 ， 该 类 的 创建 过 程 已 经 在 关键 技术 中 给 
出 ， 这 里 不 再 效 述 。 

(2) 在 listsepbook.php 文件 中 ， 包 含 网 站 头 文件 ， 根 据 超 链 接 传递 的 参数 值 为 变量 赋值 ， 调 用 数据 库 管理 
类 中 的 方法 执行 查询 语句 ， 并 且 将 返回 的 查询 结果 赋 给 模板 变量 。 定 义 分 页 变量 ， 调 用 分 页 类 中 的 方法 完成 数 
据 的 分 页 输出 ， 同 时 将 分 页 方法 返回 的 数据 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 


[Ee 


require_once ‘header.php’; // 包 含 headerphp 文件 
if($_GET[t] — new') { /展示 新 书 
Snowtype = ' 新 书 推荐 '; 
Sandwhere = "isnew = 1"; 
} elseif ($_GET[Y] 一 'sepprice) { /展示 特价 图 书 
Snowtype = 特价 图 书 '; 
Sandwhere = "issepprice = 1"; 
} elseif ($ GETI't] =— hotsell) { 
Snowtype =' 热 卖 图 书 '; // 展 示 热 卖 图 书 
Sandwhere = "ishotsell = 1"; 
} elseif ($_GET[t] 一 em) { 
/展示 明日 图 书 
// 为 模板 变量 赋值 


, Snowtype): 
S$system = EE system where mark = 1". SconnID); // 执 行 查询 语句 


S$smarty->assign('system', $system): // 将 查询 结果 赋 给 模板 变量 
让 (!isset($_GET[page]) || $_GET['page] —") { 1/ 判断 分 页 变量 的 值 

Spage ='1'; // 设 置 分 页 变量 的 值 
} else 


Spage =$_GET[page']: 
} 


$sql = "select tb_bookinfo.id. tb_bookinfo.bookimg. tb_bookinfo.about tb_bookinfo.browsertime. tb_bookinfo.oldprice. tb_bookinfo.newprice, 
tb _bookinfo bookname. tb_bookinfo.writer, tb_bookinfo pubtime. tb_bookinfo.addtime. tb_bookinfo ishave, tb_pub.pubname from tb_bookinfo, tb_pub 
where tb_ bookinfo .pubid = tb_pub.id and " . Sandwhere . " order by tb_bookinfo.addtime desc": /定义 查询 语句 

S$bookinfos = $pageDB->pageData($sql. $connID. 10. Spagej; /调用 分 页 类 中 的 方法 ， 执 行 查询 操作 
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$smarty->assign(‘bookinfos'. Sbookinfos): /| 将 分 页 方法 返回 的 数组 赋 给 模板 变量 
$smarty->display('listsepbook.phtml’); /指定 模板 页 
Tequire_once ‘footer.php'; /包含 页 面 的 尾 文件 


(3) 在 views\listsepbook.phtml 模板 页 中 完成 数据 的 分 页 输出 ， 其 代码 请 参考 光盘 中 的 内 容 。 
秘笈 心 法 
心 法 领悟 588: 分 页 方法 的 完善 。 


在 本 实例 中 ， 采 用 的 是 首页 、 上 一 页 、 下 一 页 和 尾 页 的 分 页 模式 ， 如 果 读 者 感 兴趣 也 可 以 对 这 种 分 页 模式 
进行 更 新 ， 使 其 更 加 个 性 化 ， 分 页 类 存储 于 library\ PageDB.php 文件 中 。 


~、 


图 实例 说 明 


Smarty 是 PHP 的 模板 引擎 ， 通 过 Smarty 可 以 将 开发 人 员 和 美工 人 员 相互 独立 开 来 ， 在 项 目 开发 中 ， 后 台 
编码 和 前 台 设 计 可 以 同步 进行 。 在 对 项 目 进行 维护 的 过 程 中 ,页 面 更 改 不 会 影响 业务 逻辑 的 实现 。 同 时 ，Smarty 
模板 增加 了 视图 缓存 和 静态 页 面 生成 机 制 ， 从 而 可 以 有 效 提高 项 目的 执行 效率 。 

明日 科技 图 书 网 站 就 是 应 用 Smarty 模板 完成 网 站 的 动静 分 离 的 ， 其 动态 文件 存储 于 项 目的 根 目录 下 ， 模 板 
文件 存储 于 根 目录 下 的 views 文件 夹 中 ， 而 Smarty 的 缓存 文件 和 编译 文件 则 存储 于 library\smarty 目录 下 ， 如 
图 15.12 所 示 。 


吾 Tey 
四 AD0DB 类 库 
DD fckedit 在 线 编 各 器 
局 wm 
已 缓存 文件 到 
已 一 一 一 篇 译文 件 夹 
DD 配置 文件 来 
gD lits Searty 模 板 
国 “Admin php 一 一 一 一 数据 库 扣 作 类 
国 Cert php- 购物 车 类 
轩 “conn ph 一 一 一 一 数据 库 连 接 类 
夯 PweelB. phi 分 页 
轩 ”SnartConfig php 一 一 Searty 模 板 配 置 类 
全” Wil pip 一 一 一 一 一 字符 审 处 理 类 


图 15.12 明日 科技 图 书 网 的 类 文件 存储 位 置 


关键 技术 
Smarty 模板 引擎 的 配置 类 封装 在 SmartyConfig.php 文件 中 ， 其 代码 如 下 : 
require_once ‘library/smarty/libs/Smarty.class.php’; /包含 Smarty.class.php 文件 ， 从 而 导入 Smarty 类 库 
class SmartyConfig extends Smarty { /| 编写 SmartyConfig 类 ， 使 其 继承 自 Smarty 类 
function SmartyConfig O{ /构造 方法 
S$this->SmartyO: /调用 父 类 的 构造 方法 


$arrayIni = parse_ini_file('config/lzhConfigini); /解析 LzhConfigini 文件 ， 来 获取 配置 信息 
Sthis->template_dir = SarrayIni['template_dir]: /模板 文件 保存 目录 
S$this->compile_dir = SarrayIni['compile_dir]:; /| 编译 文件 保存 目录 


Sthis->cache_dir = $arrayIni['cache_dir’]; /1 缓存 文件 保存 目录 
S$this->config_dir = $arrayInif'config dir]; /配置 文件 保存 目录 
S$this->caching = SarrayIni['caching']; // 是 否 开启 视图 缓存 


} 
} 


BY 技巧 : 函数 parse ini file0 用 于 解析 .ini 文件 ， 并 将 解析 结果 存储 到 数组 中 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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表 15.1 Util 类 中 的 方法 列表 


方 ” 法 说 明 
Util 0 构造 方法 ， 载 入 配置 文件 
baseUrl O 定义 网 站 中 地 址 的 相对 路 径 
moneyFormat($money) 对 货币 进行 格式 化 。 参 数 $money 为 金额 
unHtml ($text) 对 html 标记 进行 转 义 输出 ， 参 数 $text 为 转 义 的 文本 
对 中 文 进行 截取 ， 防 止 出 现 乱 码 。 参 数 $str， 要 截取 的 字符 串 ，$start， 开 始 截取 的 位 置 ， 


msubstr ($str, $start, $len) slen: 截取 的 长 度 


editor ($name, $value, $width ”| 集成 FCKEditor 编辑 器 。 参 数 $name: 编辑 器 名 称 ; $value: 编辑 器 内 容 ，$width: 编辑 
="'100%'. $height = '200") 器 宽度 ，$height: 编辑 器 高 度 
editorUnHtml ($text) 转 义 编辑 器 输出 内 容 。 参 数 $text 指 输出 内 容 


setRed ($arrayKey. $text 对 关键 字 描 红 。 参 数 $arrayKey: 查询 的 对 象 ，$text: 查询 的 关键 字 


图 设计 过 程 
在 library 文件 夹 下 新 建 UtilLphp 文件 ， 封 装 字符 串 类 Util， 定 义 表 15.1 中 列 出 的 字符 串 操作 方法 。 
(1) 首先 定义 该 类 的 属性 ， 充 分 考虑 到 项 目 在 生产 环境 下 的 维护 工作 ， 将 类 的 常用 配置 都 写 入 到 
LzhConfig.ini 文件 ， 所 以 该 类 的 属性 只 需要 一 个 用 来 保存 配置 文件 信息 的 数组 即 可 ， 代 码 如 下 : 


var $arrayIni; /用 于 保存 LzhConfig.ini 配置 文件 的 配置 信息 
(2) 定义 工具 类 的 构造 方法 。 在 构造 方法 中 通过 函数 parse_ini_file0 解 析 LzhConfig.ini 配置 文件 ， 实 现代 
码 如 下 : 
fanction Util O{ 
S$this->arrayIni = parse_ini_file('config/lzhConfig.ini’); // 解 析 配置 文件 ， 并 将 结果 保存 到 数组 中 
} 


(3) 一 般 情况 下 ,项 目 在 开发 环境 和 生产 环境 下 的 根 目 录 是 不 同 的 ， 如 果 开 发 过 程 中 采用 相对 路 径 ， 改 动 
较 小 ， 如 果 使 用 绝对 路 径 ， 那 么 所 有 涉及 路 径 的 模块 在 正式 发 布 项 目 时 都 需要 改动 。 为 了 解决 上 述 问题 ， 可 以 
将 项 目 根 目录 在 LzhConfig.ini 文件 中 指定 ， 然 后 在 需要 使 用 项 目 路 径 的 模块 中 读 取 配 置 文件 所 指定 的 项 目 根 目 
录 即 可 ， 这 里 获取 项 目 根 目录 应 用 的 是 baseUrl0 方 法 ， 代 码 如 下 : 

function baseUrl Of 

SarrayIni = $this->arrayIni; 
Tetum $arrayIni[baseUrl]; /将 配置 文件 中 的 网 站 根 目录 返回 

} 

(4) 作为 电子 商务 类 网 站 ,项 目的 很 多 模块 中 都 需要 实现 对 货币 金额 的 格式 化 输出 ， 为 了 简化 操作 ， 在 字 
符 串 类 中 定义 moneyFormat0 方 法 ， 其 代码 如 下 : 

function moneyFormat ($money){ 

return str_replace(,. ", number_format($money. 2)): /返回 中 文 货币 格式 

} 

利用 moneyFormat0 方 法 首先 通过 函数 number_format0 将 金额 保留 2 位 小 数 后 格式 化 输出 , 然后 将 格式 化 后 
高 位 的 “,” 替 换 为 室 ， 最 后 将 处 理 结果 返回 。 

(5) 为 了 保持 所 录入 数据 按 原 格式 输出 ， 需 要 将 一 些 特殊 字符 转 义 成 HTML 标记 ， 由 于 在 项 目的 很 多 模 
块 需要 使 用 到 该 功能 ， 所 以 将 该 功能 作为 一 个 方法 封装 到 字符 串 处 理 类 中 ， 其 代码 如 下 : 


function unHtml ($text){ 
$str = htmlspecialchars(Stext): // 将 特殊 字符 替换 成 HTML 转 义 标记 
S$str=str_replace(chr(13),"<br>".$stn): // 将 换行 替换 成 标记 <br/> 
$str = nl2br($str); // 在 每 个 新 行 前 加 入 HTML 换行 标记 <br/> 
S$str=str_replace(chr(32),"&nbsp:".$str): // 将 空格 替换 成 标记 S$nbsp; 
Tetum $str /返回 处 理 后 字符 串 


} 
(6) 使 用 PHP 提供 的 函数 substr0 截 取 中 文字 符 会 导致 截取 乱码 ， 而 且 在 制作 项 目 时 ， 很 多 模块 都 需要 对 
过 长 字符 进行 截取 ， 所 以 在 字符 串 处 理 类 中 定义 msubstr0 方 法 ， 对 中 文字 符 进行 截取 ， 其 代码 如 下 : 


831 
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function msubstr ($str, $start, $len){ 
Sstrlen = $start + Slen: 
for ($i= 0; $i< $strlen: $i ++) { 
if (ord(substr(Sstr. Si 1)) > 0xa0) { 
Stmpstr 一 substr(Sstr Si 2): 
Si+H; 
} else 
Stmpstr .= substr($str, $i, 1); 
} 
Tetum $tmpstr; 


/获取 截取 字符 长 度 

// 访 历 所 有 字符 

/1 判断 是 否 为 中 文字 符 

/和 如果 是 中 文 则 截取 2 个 字 节 


/不 是 中 文 则 截取 1 个 字 节 
/返回 结果 


} 
(7) 使 用 HTML 语言 提供 的 文件 域 对 文本 进行 编辑 。 实 现 文本 特效 较 复杂 ， 而 且 不 能 达到 “所 见 即 所 得 ” 


的 效果 ， 为 了 解决 上 述 问 题 ， 在 进行 Web 项 目 开发 时 候 ， 
域 。 在 制作 明日 科技 书店 时 会 在 很 多 模块 使 用 到 在 线 编辑 器 ， 所 以 在 开发 时 将 调 


在 UL 字符 串 处 理 类 中 ， 具 体 代码 如 下 : 
function editor ($name, $value, $width = '100%', $height = '200){ 
require_once ‘library/fckeditor/fckeditor.php’; 
SarrayIni = S$this->arrayIni; 
SoFCKeditor = new FCKeditor($name); 


$oFCKeditor->BasePath = SarrayIni[baseUrl] . Vibrary/fckeditor/: 


S$oFCKeditor->Width = $width; 
SoFCKeditor->Height = S$height: 
S$oFCKeditor->ToolbarSet = 'Default’; 
S$oFCKeditor->Value = $value; 
SoFCKeditor->Create0; 

} 


(8) 完成 Util 类 的 封装 ， 在 lzh.inc.php 文件 中 ， 


- 般 使 用 FckEditor 在 线 编辑 器 作为 表单 的 文本 编辑 
FckEditor 编辑 器 的 代码 封装 


// 导 入 FckEditor 类 库 
/获取 配置 文件 内 容 
// 实 例 FCKeditor 

// 设 置 FCKeditor 路 径 
/| 编辑 器 的 宽度 
/编辑 器 的 高 度 
/设置 工具 栏 样式 
// 初 始 值 

// 创 建 编辑 器 


应 用 Smarty 中 的 register_object0 方 法 将 其 注册 为 模板 对 


象 ， 在 模板 页 中 通过 模板 对 象 调用 类 中 方法 实现 对 字符 串 的 操作 。 


在 lzh.inc.php 文件 中 不 上 
化 对 象 ， 包 括 数据 库 连接 类 、 数 据 库 操作 类 、 

<?php 

session_startO; 

SarrayIni = parse_ini_file(configllzhConfig.ini; 

Tequire_once 'library/ConnDB.php'; 

require_once ‘library/AdminDB.php'; 

Tequire_once 'library/PageDB.php'; 

Tequire_once ‘library/SmartyConfig.php'; 

Tequire_once ‘library/Cart.php’; 

Tequire_once ‘library/Util.php'; 


SconnDB =new | ,SarrayIni['host'] .SarrayIni[userName' 


SpageDB = new PageDBO: 

Ssmarty = new SmartyConfig(); 

Sutil = new UtilO; 
$smarty->register_object('util, $util, null, false); 


实现 注册 模板 对 象 的 功能 ， 
分 页 类 和 Smarty 配置 类 ， 其 代码 如 下 : 


所 有 类 的 实例 化 操作 都 在 该 文件 中 完成 ， 并 返回 实例 


// 初 始 化 SESSION 变量 
// 包 含 配置 文件 

// 载 入 数据 库 连接 类 文件 
// 载 入 数据 库 操作 类 文件 
// 载 入 分 页 类 文件 

// 载 入 Smarty 配置 类 文件 
/ 载 入 购物 车 类 文件 
/收入 字符 串 处 理 类 文件 
] .SarrayIni[password'] .SarrayIni['dbName'] .SarrayIni['isDebug]); 
/执行 与 数据 库 的 连接 
/数据 库 操作 类 实例 化 
/分 页 类 实例 化 

Wsmarty 配置 类 实例 化 
/字符 串 操作 类 实例 化 

/ 广 册 模板 对 象 


(9) 在 index.php 文件 中 ， 调 用 数据 库 操作 类 中 的 方法 ， 查 询 出 数据 库 中 的 数据 ， 并 且 将 查询 结果 赋 给 模 


板 变 量 ， 最 终 指 定 模板 页 。 


(10) 在 模板 页 views\index.phtml 中 ， 应 用 section 语 


i 句 循 环 输出 模板 变量 中 的 数据 ， 并 且 通 过 注册 对 和 象 调 


ek 图 书 价格 和 公告 标题 等 进行 格式 化 操作 ， 其 关键 代码 如 下 : 


{section name=rID I 
<div style="width: 198px: 让 bottom: 7px"> 
<div style="width:1009%%; height:90px"> 
<div style="width:85px:; height:100px: float:left"> 


<a href=" {util->baseUrl}/bookinfo-{$reads[frID].bookid}.html"><img src="{$system[O01.bookimgurl}/{$reads[rID].bookimg}" 


width="70" height="90” style="border: 1px solid #123456" /></a> 
<div> 


<div style="width:112px: height:100px: float:right: text-align:left"> 
li style="display:inline: height:35px"><a href=" {util->baseUrl}/bookinfo-{$reads[rID].bookid} html" class="a6">* {util->unHtml 


p=S$reads[rID].bookname}</a></li> 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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包含 文件 是 指 将 另 一 个 文件 中 的 内 容 包含 到 当前 文件 中 来 。 包 含 外 部 文件 可 以 提高 代码 的 重用 率 ， 是 PHP 
编程 的 重要 技巧 。PHP 提供 了 include、require、include_once 和 require_once 语句 用 于 实现 包含 文件 操作 。 

使 用 require 语句 调用 文件 时 ， 如 果 调 用 的 文件 没 找到 ，require 语句 会 输出 错误 信息 ， 并 且 立 即 终止 脚本 的 
处 理 。 而 include 语句 在 没有 找到 文件 时 会 输出 警告 ， 但 不 会 终止 脚本 的 处 理 。 

使 用 require 语句 调用 外 部 文件 时 ， 只 要 程序 一 执行 ， 就 会 立刻 调用 ; 而 使 用 include 语句 时 ， 只 有 程序 执 
行 到 该 语句 时 ， 才 会 调用 外 部 文件 。 


中 级 
趣 叶 指数， 会 食 疹 


图 实例 说 明 


明日 科技 图 书 网 尾 文件 也 是 作为 单独 的 文件 进行 存储 的 ， 其 运行 效果 如 图 15.15 所 示 。 
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Copyriaht 全 长 大 明日 入 书 相 1998-2010，Al Bights Reserved| 二 1CT 备 T0312345 昌 


图 15.15 ”网 站 尾 文件 的 运行 效果 


图 关键 技术 


网 站 尾 文 件 在 输出 各 种 超 链接 的 同时 , 还 输出 数据 库 中 tb_system 表 中 的 数据 , 其 存储 的 是 项 目的 系统 信息 。 
tb_system 表 的 结果 如 图 15.16 所 示 。 

在 运行 明日 科技 图 书 网 的 程序 时 ， 要 对 tb_system 表 中 readurl、bookimgurl 和 ggurl 3 个 字段 的 值 进行 修改 ， 
以 设置 正确 的 程序 路 径 ， 如 图 15.17 所 示 。 


中 服务 器 : localhost } 曲 元 据 库 : db_database15， 国 表 ;tb_system 
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图 15.16 ”明日 科技 图 书 网 的 系统 表 结 果 15.17 ”设置 程序 在 服务 器 中 的 相对 路 径 
笔者 在 开发 本 项 目 时 ， 将 其 存储 于 Apache 服务 器 的 mr/15/005 文件 夹 下 。 读 者 在 运行 程序 时 ， 需 要 根据 自 
己 的 实际 情况 对 这 个 路 径 进行 修改 。 
图 设计 过 程 
(1) 新 建 footer.php 文件 ， 读 取 项 目 系 统 表 tb_system 中 的 数据 ， 并 且 将 数据 存储 到 模板 变量 中 ， 同 时 指 
定 模板 页 ， 其 代码 如 下 : 
php 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(2) 将 lzhScrollImgjs 脚本 文件 存储 于 本 实例 根 目录 的 js 文件 夹 下 。 
图 秘笈 心 法 


心 法 领悟 593: js 特效。 
读者 不 必 自 己 研究 js 脚本 特效 的 实现 方法 ， 可 以 充分 利用 网 络 资源 ， 查 找 自 己 喜欢 的 特效 代码 ， 然 后 将 其 
应 用 到 自己 的 程序 中 即 可 。 


15.3 注册、 登录 


明日 科技 图 书 网 用 户 登 录 模 块 的 主要 功能 是 为 用 户 提供 服务 、 建 立 网 站 管理 者 和 用 户 沟通 的 桥梁 ， 主 要 包 
括 用 户 注册 、 用 户 登录 、 用 户 注册 信息 修改 、 用 户 密 码 修改 、 查 看 提交 订单 信息 和 查看 在 网 站 上 的 消费 情况 等 
功能 。 


趣味 指数 : 窒 侠 会 | 


图 实例 说 明 


用 户 注册 模块 主要 用 于 对 用 户 注册 信息 进行 收集 ， 用 户 再 次 参与 该 站 点 活动 时 ， 通 过 登录 模块 成 功 登录 后 
即 可 参与 进来 。 用 户 注册 模块 不 仅 可 以 方便 用 户 参与 本 站 活动 ， 而 且 也 是 对 网 站 人 气 的 积累 。 明 日 网 上 书店 的 
用 户 注册 表单 如 图 15.19 所 示 。 
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图 15.19 用 户 注册 表单 


力 关键 技术 


(1) 图 片 验证 码 。 

制作 图 片 验证 码 时 ， 首 先 通过 JavaScript 的 Math 对 象 的 random0 方 法 产生 一 个 随机 数 ， 并 通过 Math 对 象 
的 round0 方 法 截取 该 随机 数 的 前 4 位 。 然 后 再 分 别提 取 该 随机 数 的 每 一 位 ， 并 将 提取 的 每 一 位 数字 通过 GET 
方法 传递 到 xym.php 页 面 ， 在 xym.php 页 面 中 根据 传递 过 来 的 数组 读 取 相应 的 图 片 ， 并 将 结果 显示 出 来 ， 其 代 
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echo fread(Sfp,filesize(Saddress)); 
felose($fp); 


/获得 传递 的 数字 

/获取 对 应 图 片 地 址 

/打开 对 应 的 图 片 

/将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 
1 美 闲 打 开 的 图 片 


在 将 生成 的 随机 数 的 每 一 位 传递 到 xym.php 文件 的 同时 ， 将 该 随机 数 赋 给 一 个 隐藏 域 ， 这 样 在 验证 用 户 输 
入 的 验证 码 是 否 正 确 时 , 就 可 以 根据 用 户 输入 的 内 容 和 该 隐藏 域 的 value 值 进行 对 比 得 出 结果 , 如 果 二 者 相等 则 


说 明 用 户 输 入 的 验证 码 正确 。 
(2) 验证 用 户 输入 的 用 户 名 是 否 被 占用 。 


当 用 户 输入 注册 信息 时 , 应 用 JavaScript 对 用 户 输 入 的 内 容 进行 实时 验证 , 其 中 验证 用 户 名 是 否 被 占用 的 方 


法 存储 于 \sfunjs 文件 中 ， 其 代码 如 下 : 
function chkreginfo(form, mark, edit, baseUrD { 
if((mark =— 0|| mark 一 "all") && edit != "edit") { 


if(form.usernc.value —"") { // 判 断 用 户 输入 的 昵称 是 否 为 空 
chkusermnc.innerHTML = "请 输入 用 户 上 昵称! "; // 如 果 为 空 则 给 出 提示 
form usemec.style .backgroundColor = "#FF0000": // 更 改 用 户 昵 称 文本 框 的 背景 为 红色 
Teturn false; 
} else { 
var xmlobj; /定义 XMLHttp 对 象 
if (window.ActiveXObject) { // 如 果 是 Windows 系统 
xmlobj = new ActiveXObject("Microsoft XMLHTTP"): /通过 ActiveXObject0 实 例 XMLHttp 对 象 


} else if (window.XMLHttpRequest) { 
xmlobj = new XMLHttpRequestO; 


} 
Xmlobj.onreadystatechange = fun; // 设 置 回 调 函 数 


/通过 XMLHttpRequest0 实 例 XMLHttp 对 象 


xmlobj.open("GET"、 /通过 GET 方法 向 服务 器 发 送 数据 
baseUrl + "chkunc.php?unc=" + form.userne.value, true); 

xmilobj.send(null); 

function fun0 { /定义 回调 函数 


if (xmlobj.readyState 一 4 &é& xmlobj status 一 200) { 

if (xmilobj.responseText =— "0") { 
chkusemc.innerHTML = "该 昵称 已 被 占用!"; 
form.usernce.style.backgroundColor = "#FF0000"; 
Teturn false; 

Yelse{f 
chkusernc.innerHTML = 
form.usemnec. = "#FFFFFF"; 


/如 果 返 回 0 则 说 明 昵称 被 占用 


| 


} 
} 


} 
ee 1/ 省 略 代码 请 详 见 本 书 附带 光盘 
Teturn true; 


} 
上 述 代 码 首先 根据 不 同 浏览 器 的 类 型 生成 HTTP 请 求 对 象 ， 然 后 使 用 该 对 象 的 open0 方 法 将 用 户 输入 的 昵 
称 传递 给 chkunc.php 页 面 ， 并 根据 chkunc.php 页 面 的 返回 值 判断 用 户 输入 的 昵称 是 否 已 经 被 占用 ， 其 中 


chkunc.php 的 关键 代码 如 下 : 
Tequire_once ‘lzh.inc.php': /包含 公共 类 
S$arrayunc=$adminDB->executeSQL("select id.userne from tb_user where usernc=".$_GET["unc"]."".$connID); /查找 用 户 昵称 
if($arrayunc) 
echo 0: /如果 查 找到 则 返回 0 
else 
echo 1: /没有 查 到 则 返回 1 
图 设计 过 程 


(1) 制作 用 户 注册 表单 UI 界面 。 用 户 注册 表单 除 用 户 名 和 登录 密码 等 信息 外 ， 为 了 与 用 户 进行 沟通 ， 还 
需要 用 户 的 联系 电话 、E-mail 地 址 和 邮编 等 信息 ， 据 此 编写 明日 科技 书店 的 注册 表单 ， 模 板 页 getuserinfo .phtml 
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的 主要 代码 如 下 : 
<form name="form reg" method="post" action=" {util->baseUrl}/getuserinfo.php" onSubmit="return chkreginfo(form reg.'all)"> 
<table width="90%" border="0" align="center' cellpadding="0" cellspacing="0"> 
<t> 
<td width="22%" height="30"><div align="right"> 用 户 上 昵称: </div></td> 
<td colspan="3">&nbsp:<input type="text" name="usemc" size="20" class="input" onBlur="chkreginfo(form reg.0, ", {util->baseUrl})"></td> 
<td width="25%"><div id="chkusernc" style="color:#FF0000"></div></td> 
</> 
<t> 
<td height="30"><div align="right"> 登 录 密 码 : </div></td> 
<td height="30" col ="3">&nbsp;<input type="password" name="userpwd1" size="25" class="input" onBlur="chkreginfo(form reg,1)" 
></td> 
<td height="30"><div id="chkuserpwd1" style="color:-#FF0000"></div></td> 
</> 
…-<! 一 此 处 省 略 部 分 表单 元 素 实现 代码 ， 请 详 见 本 书 附带 光盘 -> 
<t> 
<td height="30"><div align="right"> 验 证 码 : </div></td> 
<td width="1796" height="0">&nbsp:<input type="text" name="xym" size="8" class="input' onBlur="chkreginfo(form_reg,12)"/><input 
type="hidden" value="" name="xym1"></td> 
<td width="12%"> 
<script language="javascript"> 
var numl=Math round(Math randomO*10000000): 
varnum=numl.toString0.substr(0.4): 
document.write("<img name=codeimg4 src="{util->baseUrl}/xym.php?num="+num.substr(0,1)+"&baseUrl={util->baseUrl}'>"); 
document.write("<img name=codeimgs src="{util->baseUrl}/xym.php?num="+num.substr(1,1)+"&baseUrl={util->baseUrl}'>"); 
document.write("<img name=codeimg6 src="{util->baseUrl}/xym.php?num="+num.substr(2,1)+"&baseUrl={util->baseUrl}'>"); 
document. Sd name=codeimg7 src="{util->baseUrl}/xym.php?num="+num.substr(3,1)+"é&:baseUrl={util->baseUrl}'>"); 
form reg.xyml.value=num; 
<! 一 该 方法 用 于 实 驱 量 新 为 验证 码 工 值 -> 
fonction code_10 {ldelim} 
Var num1=Math.round(Math.random()*10000000); 
Var num=num1 .toString().substr(0,4); 
document.codeimg4.sre=" {util->baseUrl}/xym.php?num="+num.substr(0,1)+"&:baseUrl={util->baseUrl}"; 
document.codeimg5.sre=" {util->baseUrl}/xym.php?num="+num. substr(1,1)+"&baseUrl={util->baseUrl}"; 
document.codeimg6.sre=" {util->baseUrl}/xym.php?num="+num.substr(2,1)+"&:baseUrl={util->baseUrl}"; 
‘document.codeimg7.sre=" {util->baseUrl}/xym.php?num="+num.substr(3,1)+"&:baseUrl={util->baseUrl}"; 
form reg.xyml.value=num:; 
{rdelim} 
</script></td> 
<td width="24%"><a href="javascript:code_10" class="a1"> 看 不 清 </a></td> 
<td height="0"><div id="chkxym" style="color:-#FF0000"></div></td> 
</a> 
<t> 
<td height="40" colspan="5"><div align="center"> 
<input type="submit" value=" 立 即 注册 " class="btn_grey"> 
<input type="reset" value=" 重 置 " class="btn_grey”> 
</div> 


(2) 当 用 户 输入 注册 信息 时 ， 应 用 JavaScript 对 用 户 输入 的 内 容 进行 实时 验证 ， 其 JavaScript 脚本 存储 于 
Visvfunjs 文件 中 ， 完 整 代码 请 参考 本 书 光盘 。 

(3) 用 户 输入 的 内 容 成 功 通过 数据 有 效 性 验证 后 ， 所 有 输入 的 内 容 将 被 提交 到 getuserinfo.php 页 面 进行 保 
存 ， 其 关键 代码 如 下 : 


Tequire_once ‘header.php’; /包含 header.php 文件 
if(isset($_POST["userne"]) && $_ POST["useme"] ="") { // 判 断 是 否 提交 了 表单 
if(! $adminDB->executeSQL("select id, usernc from tb_user where usermc=" . $ POST["useme"] . "". SconnID)) { < // 判 断 昵称 是 否 被 占用 
Stime = date("Y-m-d H:i:s"): /获取 注册 时 间 
if ($adminDB->executeSQL("insert into 
th_user(useme,truename.pwd.email.sex.tel.qq.address.ogintimes.regtime.lastlogintime.:ip.yb.usertype.answer.question.truepwd.photo,score) values(" . 
$_POST["useme"] . "," . $_POST["truename"] . "." . md5(trim($_POST["userpwd1"]) . "." . $ POST["email"] . "." . $_POST["sex"] . "." . 
$_POST["tel"] . "," .$_POST["gq"] ."." .$ oT "] . "0'$time','Stime'." . $ SERVER[REMOTE ADDR'].™.".$ POST["yb"] . "0." . 
$_POST["answer"] . "," . $_POST["question"] . "." . trim($_POST["userpwd1"]) . "." . "img/face/" . $ POST["photo"] . ",30)", $connID)) { 
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/保存 用 户 的 注册 信息 
if (isset($_SESSION["unc"]) &é&: $_SESSION["unc"] ="") { 
unset($_SESSION["unc"]D): 
} /销毁 原来 登录 用 户 的 登录 昵称 
session register("unc"); /注册 新 的 用 户 昵称 到 SESSION 变量 
$_SESSION["unc"] = trim($_POST["userne"]): 
if (isset($_SESSION['toUrI])) { /获取 要 跳 转 的 页 面 ， 并 进行 跳 转 
echo "<script>window location href=" . Sutil->baseUrl0) . "/" . $ SESSIONTtoUrl] . ™:</script>"; 
}elsef 
echo “<script>window.location href=" . $util->baseUrl() . "/regsuccess.html';</script>"; 
和 
jelse 
echo "<script>alert( 注 册 失 败 ， 请 重 试 ! )</script>"; 
》 
}else{ 
echo "<script>alert(' 该 昵称 已 经 被 他 人 注册 ! ”</script>"; 
} 
} 
$smarty->display( ‘getuserinfo.phtml); 


Tequire_once ‘footer.php’; 
图 秘笈 心 法 


心 法 领悟 594: 防止 用 户 越过 表单 限制 上 传 数据 。 

在 本 项 目的 getuserinfo.php 文件 中 , 为 了 避免 由 于 用 户 的 浏览 器 禁用 JavaScript 脚本 功能 而 使 用 户 输入 昵称 
的 唯一 性 验证 失效 ， 或 者 某 些 用 户 越过 表单 的 验证 机 制 直接 上 传 数据 ， 在 保存 用 户 提交 的 注册 信息 前 ， 首 先 使 
用 数据 库 管 理 类 的 executeSQL0 方 法 查询 是 否 存 在 和 用 户 提交 昵称 相同 的 注册 用 户 ， 如 果 存 在 则 提示 该 昵称 已 
被 占用 ， 并 返回 注册 页 面 要 求 用 户 重新 填写 注册 信息 ， 反 之 则 将 用 户 提交 的 注册 信息 保存 到 数据 库 中 。 


二 人 
四 实例 说 明 和 届 日 网上 书店 )》 几 户 登录 ee 
用 户 在 明日 科技 图 书 网 购买 图 书 时 , 需要 首先 登录 。 | 
站 点 , 这样 可 以 记录 购买 人 信息 ,并 且 可 在 用 户 中 心 的 wa eee 
订单 查询 模块 中 查询 到 该 用 户 的 所 有 订单 信息 。 明日 科 0 es 
技 图 书 网 的 用 户 登录 页 面 如 图 15.20 所 示 。 天 本 mea 


加 到 证 由 文本 性 中 


关键 技术 图 15.20 用 户 登 录 页 面 
登录 的 目的 就 是 为 用 户 开 据 一 张 通行 证 ， 使 其 可 以 在 网 站 中 进行 任意 操作 (权限 范围 之 内 ) ， 也 是 其 行使 
网 站 会 员 权限 的 依据 。 而 这 个 通行 证 的 开 据 应 用 的 是 SESSION 技术 。 登 录 成 功 后 ， 将 用 户 名 存储 到 SESSION 
变量 中 ， 即 完成 通行 证 的 开 据 ， 其 代码 如 下 : 
$_SESSION['unc'] = $userne: 
< 注意 : 在 应 用 SESSION 变量 之 前 ， 切 记 一 定 要 应 用 session startO 函 数 初 始 化 SESSION 变量 ， 否 则 SESSION 
变量 不 能 使 用 ， 并 且 在 应 用 session startO 函 数 之 前 不 能 有 任何 输出 。 本 项 目 中 SESSION 变量 的 初始 
化 操作 是 在 包含 文件 lzhinc.php 中 完成 的 。 


该 功能 利用 SESSION 可 以 在 页 面 之 间 传递 数据 的 特性 ， 确 保 这 个 通行 证 在 网 站 的 任意 一 个 页 面 中 都 有 效 ， 
直到 用 户 退出 登录 。 


力 设计 过 程 


(1) 在 views 文件 夹 下 创建 login.phtml 登录 表单 的 UI 界面 ， 其 实现 方法 与 注册 表单 类 似 ， 这 里 不 再 袭 述 。 
(2) 当 用 户 单 击 “ 登 录 ” 按 钮 后 ， 将 对 用 户 输入 的 用 户 名 、 密 码 和 验证 码 进行 有 效 性 验证 ， 如 果 验 证 通过 
则 将 用 户 输入 的 数据 提交 到 login.php 中 进行 处 理 ， 关 键 代码 如 下 : 


<?php 
require_once header php' 


SerrorMsg ="; 
if(isset($_POST['usernc']) &&: $ POST[usemc] =") { // 判 断 是 否 提交 了 表单 
Susernc = trim($_POST['userne'D); /获得 提交 的 用 户 名 
Spwd = trim($_POST['userpwd"D); /获得 提交 的 登录 密码 
Suser = SadminDB->executeSQL("select id usernc from tb_user where usemc=" . Susemc . "and pwd=" . md5($pwd) . "", $connID); // 按 用 户 名 
和 密码 查询 用 户 
if(! $user) { 
SerrorMsg =' 用 户 名 或 密码 输入 有 误 ! 
}else{ 
if(isset($_SESSION["unc"]) { /| 销毁 原 登 录用 户 信息 ， 并 注册 新 登录 用 户 信息 给 SESSION 变量 
session_unregister(‘unc’); 
} 
$_SESSION[unc'] = $useme: 
@$adminDB->executeSQL("update tb_user set logintimes=logintimes+1 ,lastlogintime =" . date(Y-m-d H:i:s) . ",ip=" 
$_SERVER['REMOTE_ADDR']. "where usernc=" .$_SESSION[unc] . "", $connID); /更 改 用 户 的 登录 信息 
He SESSION[toUrl]) { 
echo "<script>window.location.href=" . Sutil->baseUrl0 . "/" . $_SESSION['toUr}'] .";</script>"; 
exitO); 
} else { 
echo "<script>window.location. href=" . Sutil->baseUrlO . "/usercenter.html':</script>"; 
exit|); 


} 

$smarty->assign('errorMsg’, $errorMsg); 

Ssmarty->display('login.phtml); 

Tequire_once ‘footer.php'; 

上 述 代 码 中 ， 首 先 定义 变量 gerrorMsg， 保 存 处 理 登录 表单 提交 数据 时 出 现 的 错误 信息 《例如 登录 失败 信息 
等 ) ， 然 后 使 用 $_POST 全 局 数组 接收 用 户 提交 的 用 户 名 和 登录 密码 ， 并 使 用 数据 库 管理 类 的 executeSQL0 方 法 
执行 查询 语句 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 更 改 用 户 登 录 次 数 和 最 后 登录 时 间 ， 反 之 
则 将 登录 失败 信息 赋 给 变量 $errorMsg， 并 传递 给 login.phtml 模板 。 


岂 笈 心 法 


心 法 领悟 595: 延长 SESSION 的 生命 周期 。 

在 开发 程序 的 过 程 中 可 能 会 遇 到 这 样 的 情况 ， 员 的 身份 登录 一 个 网 站 后 ， 若 停留 的 时 间 较 长 ， 此 时 在 
这 个 网 站 中 发 布 信息 时 ， 会 提示 “您 没有 登录 ， We 息 ”。 

之 所 以 出 现 此 类 问题 ， 就 是 因为 在 登录 时 定义 的 SESSION 变量 已 经 过 期 ， 导 致 当前 用 户 不 可 用 ， 需 要 重新 
登录 。 解 决 这 个 问题 最 好 的 方法 就 是 通过 session_set_cookie_params0 函 数 延长 SESSION 的 生命 周期 ， 将 过 期 时 
间 设置 为 0。 


| 
| 
趣味 指数 : 窗帘 侠 庙 | 


国 实例 说 明 
明日 科技 图 书 网 的 用 户 中 心 ， 主 要 用 于 实现 对 用 户 注册 信息 和 用 户 登 录 密 码 的 修改 、 用 户 订单 的 查询 和 意 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


第 15 章 ”综合 应 用 
本 框 、 新 密码 录入 文本 框 和 确认 密码 录入 文本 框 3 个 表单 元 素 ， 如 图 15.22 所 示 。 
系统 将 用 户 修改 的 数据 提交 到 usercenterchangepwd.php 页 面 ， 在 该 页 面 中 完成 对 密码 的 更 改 。 首 先 判断 用 
户 是 否 非法 登录 ， 然 后 判断 用 户 输入 的 原 密码 是 否 正确 ， 如 果 正 确 则 将 用 户 密码 更 改 成 新 值 ， 反 之 给 出 错误 提 
示 ， 其 代码 如 下 : 


<?php 
Tequire_once ,header.php' 


if(! isset($_SESSION['unc']) || $_SESSION[unc] 一 1/ 判断 用 户 是 否 已 经 登录 
echo "<script>alert( 禁 止 非 登录 ! es .Sutil->baseUrlO . "/index. html':</script>"; 
exitO; 
} 
if (isset($_POST['oldpwd") &é& $ POST['oldpwd] =") { 1/ 判断 用 户 是 否 已 经 提交 了 表单 
if(! $adminDB->executeSQL("select id, userne from tb user where usemc=" . $ SESSION['unc] . " and pwd=" .md5($ POSTF'oldpwd") .""， 
SconnID)) { 
echo "<script>alert( 原 密码 输入 有 误 ! :</script>"; /验证 原 密码 是 否 正确 
}else{ 
if ($adminDB->executeSQL("update tb user set pwd=" . md5($ POSTI'pwd1") . ", truepwd=" . $ POST[pwdl1." where usemc=" . 
$_SESSION['unc’] ."", SconnID)) { /| 执行 更 改 密码 操作 
echo "<script>alert( 密 码 更 改 成 功 ! );</script>"; 
yelse { 


echo "<script>alert( 密 码 更 改 失 败 ! ;</script>"; 
} 


} 

人 

Tequire_once ‘footer.php’'; 

(3) 意见 反馈 。 

用 户 在 参与 本 站 活动 时 ， 如 果 对 网 站 的 管理 或 运营 存在 建议 或 意见 ， 可 以 通过 用 户 中 心 的 意见 反馈 模块 将 
个 人 意见 提交 给 网 站 管理 者 。 明 日 科技 图 书 网 的 意见 反馈 表单 如 图 15.23 所 示 。 

用 户 填 写 的 反馈 意见 将 被 提交 到 userfeedback.php 页 面 ， 在 该 页 面 中 应 用 数据 库 管理 类 中 的 executeSQLO 
方法 将 反馈 意见 添加 到 tb_feedback 数据 表 中 ， 其 代码 如 下 : 


让 (isset($_SESSION[unc]) || $_SESSION[unc] —") { /1/ 判 断 用 户 是 否 已 经 登录 
echo "<script>alert( 禁 止 非 登录 ! ));window.location href=" . Sutil->baseUrlO . Windex .html:</script>": 
exit0; 
} 
if (isset($_POST['title') && $_POST['title] =") { / 测 断 用 户 是 否 六 
if (SadminDB->executeSQL("insert into tb feedback(title content addtime, userne) values(™ . $_POST['itle] . ", ". $_POST['content] .",". 
date(Y-m-d Hi:i:s) . ", " . $_SESSION['une’] . ")", $connID)) { /保存 用 户 的 反馈 意见 信息 
echo " caient 个 的 反馈 全 局 忆 忆 动 保存， 谢谢 您 的 支持 ! );</script>"; 
jelse{ 
echo "<script>alert( 反馈 信息 保存 失败 ， 请 重 试 ! );</script>"; 
} 
LL 
伟 改 登录 守 码 Et 主题 : 科 序 开发 翌 双 交流 
et 2 并 且 记 用 PEP 份 静 -| 
新 守 码 :| 本 人 也是 PP 程 序 开 发 者 ， 对 念 借用 的 技术 非常 大 兴趣 ， 希 望 候 不 吾 观 | 
Dl 后 导 册 容 : S| 
基本 国 | 法 | 


图 15.22 用 户 密码 修改 表单 


图 秘笈 心 法 


心 法 领悟 5396: 用 户 中 心 功能 总 结 。 

在 用 户 中 心 功能 模块 中 应 用 的 技术 可 以 划分 为 两 部 分 : 第 一 部 分 ， 在 Smarty 模板 页 中 创建 form 表单 ， 提 
交 用 户 需要 更 新 的 数据 ; 第 二 部 分 , 在 PHP 动态 页 中 , 应 用 数据 库 管理 类 中 的 executeSQL( 方 法 执行 select、 insert 
和 update 语句 ， 完 成 对 用 户 的 验证 、 数 据 的 添加 和 更 新 操作 。 


15.23 用户 意见 反馈 表单 


PHP 开发 实战 1200 例 (第 I 卷 ) 


| od i 


图 实例 说 明 


明日 科技 图 书 网 中 ，“ 我 的 订单 ”只 是 用 户 中 心 功能 模块 中 的 -个 子 模块 ， 其 功能 是 输出 当前 登录 用 户 的 
订单 信息 ， 同 时 可 以 查看 订单 的 详细 信息 ， 执 行 取消 订购 和 确认 收 货 的 操作 ， 其 运行 效果 如 图 15.24 所 示 。 
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图 1 15.24 我 的 订单 功能 展示 


图 关键 技术 

在 开发 “我 的 订单 ”功能 模块 时 ， 应 用 的 技术 如 下 : 

(1) 数据 库 的 连接 、 操 作 类 。 

(2) Smarty 模板 引擎 的 配置 类 。 

(3) 字符 串 的 处 理 类 ，baseUrl0 方 法 获取 网 址 的 相对 路 径 ，moneyFormat( 方 法 对 货币 金额 进行 格式 化 ， 
unHtml0 方 法 对 html 字符 串 进行 转 义 。 


(4) 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 实 现 直 接 在 Smarty 模板 页 
中 定义 JavaScript。 


上 述 技术 在 前 面 的 章节 中 进行 过 详细 的 讲解 ， 这 里 就 不 再 獒 述 。 
图 设计 过 程 

(1) 在 “我 的 订单 ”功能 模块 中 ， 所 有 的 操作 都 在 usercenterorder.php 文件 中 完成 ， 包 括 当前 用 户 订单 信 
息 的 循环 输出 、 订 单 详细 信息 的 查看 、 订 单 的 取消 以 及 确认 收 货 等 ， 其 代码 如 下 : 

<?php 


Tequire_once ,headerphp': /包含 网 页 头 文件 
证 (tisset($_SESSION[Tunc]) || $_SESSION[unc] —") { /判断 当前 用 户 的 权限 
echo "<script>alert( 禁 止 非 登 录 ! 人 ):window.location.href=".$util->baseUrl0."/index.html':</script>"; 
exitO: 
让 
iftisset($_GET['def)) && S_GET[def] 一 y){ // 如 果 变量 def 的 值 是 Y， 则 执行 确认 收 货 的 操作 
S$adminDB->executeSQL("update tb_order set issh=1 where ordemo=".S_GET[ordemo]"". $connID): 
} 
iflisset($_GET['def]) && $_ GET[def] 一 qx){ 1/ 如果 变 量 def 的 值 是 qx， 则 执行 取消 订单 的 操作 
$adminDB->executeSQL("update tb order set isqx=1 where ordemo=".$ GETfordemol"", $connID); 
} 


$isShow = 下: /初始 化 变量 值 为 了 


加 载 中 
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</div> 
{0 


力 秘笈 心 法 


心 法 领悟 5397: 实现 退出 登录 功能 。 

用 户 在 登录 成 功 后 ， 可 以 修改 用 户 注册 信息 、 修 改 用 户 登 录 密 码 、 查 看 用 户 订单 信息 和 提交 意见 反馈 等 ， 
那么 如 何 实现 退出 登录 呢 ? 

实现 退出 登录 功能 应 用 的 是 session start( 、session_ unregister0 、unset0 和 header0 函 数 。 首 先 ， 初 始 化 
SESSION 变量 ， 然 后 注销 SESSION 变量 unce， 接 着 删除 SESSION 变量 ， 最 后 跳 转 到 index.html 页 面 ， 该 功能 
存储 于 logout.php 文件 中 。 


图 实例 说 明 

在 明日 科技 图 书 网 的 用 户 登录 页 面 中 ， 有 一 个 “ 找 回 密码 ” 
超 链 接 ， 单 击 该 链接 将 执行 密码 找 回 的 操作 。 第 一 步 : 输入 用 
户 的 昵称 ， 第 二 步 : 输入 密码 提示 答案 ， 第 三 步 ， 如 果 输 入 答 
案 不 正确 ， 则 给 出 错误 提示 信息 ， 和 否则 弹出 密码 找 回 成 功 对 话 
框 ， 并且 显示 原 密码 ， 也 可 以 选择 重新 设置 密码 ， 其 运行 效果 
如 图 15.25 所 示 。 


力 关键 技术 


在 找 回 密 码 功能 实现 过 程 中 ， 应 用 到 的 技术 如 下 : 图 15.25 找 回 密码 的 操作 流程 
(1) 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 实 现 直接 在 Smarty 模板 页 
中 定义 JavaScript。 
(2) 应 用 Window 对 象 中 open0 方 法 打开 openfindpwd.php 文件 ， 开 始 执行 找 回 密码 的 操作 。 
(3) 应 用 PHP 中 提供 的 MySQL 数据 库 函 数 操作 MySQL 数据 库 ， 完 成 找 回 密码 、 更 改 密码 的 操作 。 其 中 ， 
首先 在 conn.php 文件 中 应 用 mysql_connectO、mysql_select_db0 和 mysql_query0 函 数 完成 与 数据 库 服务 器 、 数 据 
库 的 连接 ， 并 且 设 置 编码 格式 ， 其 代码 如 下 : 


?php 
S$conn=mysql_connect("localhost","root","111"); // 连 接 数 据 库 服 务 器 
mysql_select_db("db_database15",$conn): /连接 数据 库 
mysql_query("set names gb2312"); /设置 数据 库 编码 格式 
?> 
设计 过 程 


(1) 在 模板 页 login.phtml 中 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 直接 编写 JavaScript 脚本 方法 


openfindpwd0， 打 开 openfindpwd.php 文件 ， 其 关键 代码 如 下 : 
<script language—"JavaScript" type—"text/avascript"> 
function openfindpwdO 
ldelim 
Ue 
");{rdelim} 
</script> 
<a href="javascript:openfindpwdO" class="a1">[ 找 会 密码 ]</a> 
(2) 新 建 openfindpwd.php 文件 ， 创 建 form 表单 ， 提 交 要 找 回 密码 的 用 户 的 昵称 ， 并 且 通 过 JavaScript 脚 
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本 判断 用 户 提交 的 数据 是 否 为 室 ， 将 数据 提交 到 findpwd.php 页 面 。 

(3) 新 建 fndpwd.php 文件 。 首先 ， 包 含 数据 库 连 接 文件 conn.php， 然 后 判断 用 户 提交 的 昵称 在 数据 库 中 
是 否 存在 ， 如 果 存 在 则 输出 此 用 户 注册 时 填写 的 密码 提示 问题 ， 并 且 通 过 form 表单 将 问题 的 答案 提交 到 
showpwd.php 文件 中 进行 处 理 。 

(4) 新 建 showpwd.php 文件 ,首先 包含 数据 库 的 连接 文件 conn.php， 然后 判断 用 户 提 交 的 问题 答案 是 否 正 
确 ， 如 果 不 正确 则 给 出 提示 信息 ， 并 跳 转 到 上 一 页 ;如 果 正 确 则 输出 显示 原 密码 和 重 设 密码 的 超 链接 。 

(5) 新 建 changepwd.php 文件 , 创建 重新 设置 密码 的 formm 表单 ,将 重新 设置 的 密码 提交 到 savechangepwd.php 
文件 中 。 

(6) 新 建 savechangepwd.php 文件 ， 完 成 用 户 密码 的 更 新 ， 其 代码 如 下 : 


<?php 

include_once ("conn.php"); // 连 接 数据 库 

Struepwd = $_POST[userpwd1]:; /获取 提交 的 新 密码 
Spwd = md5($truepwd); /对 密码 进行 md5 加 密 


if (mysql_query("update tb_user set pwd='$pwd',truepwd='$truepwd' where id=" . $ POST["userid"] . "". $conn)) { // 执 行 更 新 操作 
echo "<script>alert( 密 码 更 改 成 功 !):history.backO:</script>": 
}else{ 


echo "<script>alert( 密 码 更 改 失 败 !"):history.backO;</script>"; 
| 
mysql_close($conn); /关闭 数据 库 连 接 
?> 
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心 法 领悟 598: MySQL 数据 库 函 数 。 

在 明日 科技 图 书 网 站 项 目 中 ,为 了 体现 本 章 内 容 的 综合 性 ， 不 但 应 用 Smarty 模板 和 ADODB 类 库 技术 ， 同 
时 也 融入 了 MySQL 函数 操作 MySQL 数据 库 的 方法 。 有 关 通 过 MySQL 函数 操作 MySQL 数据 库 的 详细 讲解 可 
以 参考 第 8 章 的 内 容 。 


15.4 数据 的 输出 


本 节 将 介绍 数据 输出 功能 的 实现 ， 包 括 图 书 导航 、 图 书 分 类 、 特 别 图 书 、 图 书 试 读 、 图 书 详细 信息 和 新 闻 
公告 等 功能 。 


图 实例 说 明 
明日 科技 图 书 网 站 中 ， 通 过 图 书 导航 功能 展示 出 网 站 中 图 书 的 所 有 类 别 ， 并 且 
将 图 书 划分 为 初级 .中 级 和 高 级 3 种 类 型 , 图 书 导 航 功 能 的 运行 效果 如 图 15.26 所 示 。 


图 关键 技术 


实现 图 书 导 航 功 能 应 用 的 关键 技术 如 下 : 

(1) 在 index.php 动态 页 中 ， 应 用 数据 库 管理 类 中 的 executeSQL( 方 法 查询 出 图 书 大 类 和 小 类 数据 表 中 的 
数据 。 其 中 关于 数据 库 的 连接 和 操作 方法 可 以 参考 本 章 实例 586 和 实例 587。 

(2) 在 index.phtml 模板 页 中 ， 应 用 Smarty 模板 中 的 让 语句 根据 模板 变量 传递 的 值 判断 应 具体 输出 哪 种 类 

型 的 数据 ， 然 后 应 用 section 语句 进行 嵌 套 ， 完 成 图 书 大 类 与 小 类 的 对 应 循环 输出 。 


图 15.26 图书 导航 功能 
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有 关 Smarty 模板 中 让 语句 和 section 语句 的 详细 讲解 可 以 参考 第 14 章 的 内 容 。 
图 设计 过 程 
(1) 在 index.php 动态 页 中 ， 首 先 判断 变量 $cctype 的 值 ， 如 果 为 室 ， 则 赋值 为 1， 否 则 直接 将 变量 的 值 赋 
给 模板 变量 。 然 后 ， es 管理 类 中 的 executeSQL (方法 查询 th te 和 tb_smalltype 表 中 存储 的 图 书 类 


别 数 据 ， 同 样 将 查询 结果 赋 给 模板 变量 ， 其 关键 代码 如 下 : 
if(!isset($_GET['cctype]) 本 $ ld ey 1/ 判断 变量 值 是 否 为 空 
Scctype=1'; // 为 变量 赋值 
jelse{ 
Scctype =$ GETh'cctype'l: 
Ssmarty->assign('cctype', Scctype); // 将 变量 值 赋 给 模板 变量 
// 查 询 图 书 大 类 中 的 数据 
Sbigtypes = $adminDB->executeSQL("select id, typename from tb bigtype order by addtime", $connID): 
$smarty->assign('bigtypes'. Sbigtypes); 
/查询 图 书 小 类 中 的 数据 


S$smalltypes = $adminDB->executeSQL("select id, typename, bigtypeid from tb smalltype order by addtime", $connID); 
$smarty->assign('smalltypes', $smalltypes); 


(2) 在 index.phtml 模板 页 中 ， 根 据 模板 变量 的 值 判断 输出 全 部 图 书 导 航 、 初 级 入 门类 图 书 、 提 供 必 备 类 


图 书 还 是 高 级 导向 类 图 书 ， 然 后 通过 section 语句 嵌 套 循环 输 出 所 有 图 书 类 别 ， 其 关键 代码 如 下 : 
{section name=bID loop=$bigtypes} 
<div style="width:195px"> 
<div style="width:100%; height:25px; text-align:left; padding-left:6px; padding-top:5px: color:#990000"> 
和 ‘&nbsp; {util->unHtml p=$bigtypes[bID].typename} 
iv> 
<div style="width:100%"> 
{section name=sID loop=$smalltypes} 
{if $bigtypes[bID].id 一 $smalltypes[sID].bigtypei 
<div style="width:49%; height: 18px; float:left; text-align:left: padding-left:12px"> 
“&nbsp;<a href=" {util->baseUrl}/listbook-{$smalltypes[sID].id}-{if ee 1}1{elseif $cctype—2}2 {elseif $cctype—3}3 {elseif 
ee html" class="a4"> {util->unHtml p=$smalltypes[sID].typename}</a> 
人 0” 
{/section} 
</div> 
<div> 
{/section} 


秘笈 心 法 

心 法 领悟 $99: section 语句 的 霸 套 循环 。 

section 语句 的 嵌 套 循环 ， 需 要 让 语句 的 辅助 才能 够 完成 。 首 先 ， 执 行 section 语句 的 外 层 循环 ， 并 输出 指定 
的 数据 ， 然 后 执行 section 语句 的 内 层 循环 ， 在 内 层 循 环 中 应 用 让 语句 进行 判断 ， 当 外 层 循环 中 的 指定 值 与 内 层 
循环 中 的 指定 值 相同 时 ， 才 输出 内 层 循 环 中 的 指定 数据 。 
在 本 实例 中 ， 首 先 循环 输出 模板 变量 $bigtypes 中 的 类 型 名 称 ， 然 后 执行 内 层 循环 输出 模板 变量 $smalltypes 
中 的 数据 ， 此 时 应 用 站 语句 进行 判断 ， 只 有 当 $bigtypes 中 的 id 与 $smalltypes 中 的 bigtypeid 值 相同 时 ， 才 输出 
$smalltypes 中 的 类 型 名 称 ， 并 且 为 这 个 类 型 名 称 创建 超 链接 。 


二 指数 : 次 刘 刘 家 | 
图 实例 说 明 


明日 科技 图 书 网 是 一 个 专业 的 IT 类 图 书展 示 和 销售 平台 ， 为 了 方便 读者 选 购 ， 特 将 图 书信 息 按 类 别 展现 出 
来 。 用 户 在 选 购 图 书 时 ， 首 先 选择 图 书 大 类 ， 然 后 在 大 类 中 选择 图 书 的 小 类 ， 这 样 就 可 以 将 该 类 别 的 所 有 图 书 


第 15 章 ”综合 应 用 
以 分 页 的 形式 展现 出 来 。 明 日 科技 图 书 网 图 书 分 类 展示 效果 如 图 15.27 所 示 。 


当 击 加 16a 次: 二 :三 过 有 示 10 本 第 1 页 | 共 1 页 下 页 上 一 页 | 下 -页 区 页 


图 书 大 类 
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15.27 明日 科技 图 书 网 图 书 分 类 展示 效果 


图 关键 技术 

实现 图 书 分 类 展示 的 关键 是 数据 表 的 创建 , 在 图 书 大 类 表 tb_bigtype 和 图 书 小 类 表 tb_smalltype 之 问 存在 一 
个 关联 的 字段 ， 通 过 该 字段 确立 两 个 表 中 数据 的 从 属 关 系 。 这 里 将 tb_bigtype 表 中 的 id 字段 与 tb_smalltype 表 
中 的 bigtypeid 字段 建立 关联 ， 即 在 tb_smalltype 表 中 ， 根 据 字 段 bigtypeid 的 值 可 以 确定 该 小 类 属于 哪个 大 类 。 
图 设计 过 程 

在 图 书 分 类 展示 页 面 中 ， 浏 览 者 可 以 从 最 上 面 的 图 书 大 类 中 选择 要 购买 图 书 的 大 类 ， 然 后 在 子 类 中 选择 具 
体 的 语言 类 别 ， 这 样 就 可 以 将 指定 语言 类 别 的 图 书展 示 出 来 ， 同 时 可 以 按照 指定 的 排列 方式 和 图 书 层次 对 图 书 
的 显示 顺序 进行 调整 。 具 体 实 现 过程 如 下 : 

(1) 在 listbook.php 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 传递 到 页 面 的 排序 方式 标识 、 图 书 层次 标识 和 
当前 页 显示 的 页 码 ， 然 后 使 用 分 页 类 的 pageData0 方 法 获取 分 页 参数 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 

if(! a I$_GET[pltype] —") { /获得 图 书 排列 方式 

Spltype = "1'; 


}elsef 


Spltype = $_GET['pltype']; 


$smarty->assign('pltype'. $pltype): 
if (! isset($ GET[ectype]) ll$_GET[cctype] —") { /获得 图 书 层次 标识 


{ 

$cctype = $_GET['cctype']: 

} 

Ssmarty->assign('cctype', Scctype): 

证 (tisset($_GET[page]) || $_GET['page] —") { /获得 当前 要 显示 的 页 码 
Spage ="1'; 

}else{ 
Spage =$ GETTpageT 


Ssmarty->assign('page', Spage); 

$smalltype = $adminDB->executeSQL("select id. bigtypeid. typename from tb_smalltype where id-'Sstid". $connID); /查询 图 书 小 类 
Ssmarty->assign('smalltype'. $smalltype); 

Sbigtype = $adminDB->executeSQL("select id typename from tb_bigtype where id=" . Ssmalltype[0][bigtypeid] . "". $connID): 


Ssmarty->assign('bigtype'. $bigtype): 

$smalltypes = $adminDB->executeSQL("select id. typename from tb_smalltype where bigtypeid=" . Sbigtype[0][id] . "", $connID); /查询 图 书 大 类 
Ssmarty->assign('smalltypes'. Ssmalltypes): 

if($cctype —'1) { /设置 图 书 层次 条 件 


Swhere =" and smalltypeid =" . $stid .™"; 
}elseif ($cctype — 2) { 
Swhere =" and bookcc = 1 and smalltypeid =" . $stid .™"; 
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} elseif (Scctype 一 3) { 
Swhere =" and bookcc =2 and smalltypeid =" . $stid . ™"; 
} elseif (Scctype — 4) { 
Swhere =" and bookcc =3 and smalltypeid =" . $stid . ™"; 
} 
if($pltype —'1) { /设置 图 书 排列 方式 
S$order = "addtime desc"; 
} elseif (Spltype — 2) { 
Sorder = "pubtime desc"; 
} elseif (Spltype — 3") { 
Sorder = "newprice asc"; 
} elseif (Spltype — 4) { 
Sorder = "browsertime desc"; 
} 
$sql = "select tb_bookinfo.id., tb_bookinfo.bookimg, tb_bookinfo.oldprice, tb_bookinfo.newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
tb_bookinfo.bookname. tb_bookinfo.writer, tb_bookinfo pubtime, tb 1 De tb_bookinfo.ishave, tb_pub.pubname from tb_bookinfo, tb_pub 
Where tb_bookinfo.pubid = tb_pub.id " . $where . " order by " . $order . " // 构 建 查询 语句 
$bookinfos = $pageDB->pageData($sql, $connID, 10, Spage): /执行 分 页 查询 
S$smarty->assign(bookinfos'\ $bookinfos); 
(2) 在 views\listbook.phtml 模板 页 中 ， 应 用 section 语句 完成 指定 类 别 图 书信 息 的 分 页 显示 ， 关 键 代码 如 下 : 
{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 
<b> 
<div style="width:100%%; height:180px"> 
<div style="width:20%%; height:100%%; float:left"> 
<a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} html"><img sre=" {$system[0].bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border 1px solid #123456" /></a> 
<div> 
<div style="width:78%; height:10096: float:right:; text-align:left; font-size: 13px"> 
<li style="display:inline"><a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname)} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 : {$bookinfos.data[pbID].pubname}</li> 
<br><br> 

<li style="display:inline"> 作 者 : {Sbookinfos data[pbID] writerj</i> 
<br><br> 


<li style="display:inline"> 上 架 时 间 : {$bookinfos.data[pbID].addtimeltruncate:10:""}&nbsp;&nbsp; 出 版 时 间 : 
{$bookinfos.data[pbID].pubtimeltruncate:10:""} &nbsp:&nbsp: 浏 览 次 数 : {$bookinfos.data[pbID].browsertime}&nbsp; 次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 ，<img src=" {util->baseUrl}/img/mark_green.gif />&nbsp:<s> {util->moneyFormat 
P=S$bookinfos.data[pbID].oldprice}</s>&nbsp:&nbsp:<font color="#FF0000"> 会 员 价 : <img src=" {util->baseUrl}/img/mark_red.gif" 
/>&nbsp; {util->moneyFormat p=$bookinfos.data[pbID].newprice}</font> 
<li> 


<br><br> 
<li style="display:inline"><a href=" {util->baseUrl}/cart-{$bookinfos.datafpbID].id}-add.html"><img src=" {util->baseUrl}/ 
img/button order.gif' border="0"/></a>&-nbsp;<a href=" {util->baseUrl}/bookinfo-{$bookinfos.datafpbID].id}.html"><img src=" {util->baseUrl}/img/ 
button_info,gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:50px:; border: 1px solid #CCCCCC: text-align:left; line-height: 18px; color:#990000; padding:5px"> 
{util->unHtml p=$bookinfos.datafpbID].aboutltruncate:420:"...":false} 
</div> 
<div> 
{/section} 
{else} 
<div style="width:500px: height:80px: font-size:14px: color:-#FF0000"> 
<img src=" {util->baseUrl}/img/mark telllogin gif'><br /> 
<strong> 对 不 起 ， 暂 无 该 类 图 书 ! </strong> 
<div> 
{i 
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心 法 领悟 600: 为 什么 编辑 的 模板 页 文件 后 绥 是 .phtml， 而 输出 时 文件 的 后 缀 是 .html。 
因为 本 项 目的 开发 应 用 PHP 伪 静 态 技 术 ， 会 对 输出 文件 的 后 绥 和 传递 的 参数 进行 重新 定义 。 伪 静态 技术 的 
要 通过 .htaccess 文件 。 
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力 实例 说 明 
为 了 满足 不 同 用 户 的 需要 ， 在 制作 明日 科技 图 书 网 时 ， 设 置 了 特别 图 书展 示 模 块 ， 该 模块 可 以 对 新 书 、 特 
价 图 书 、 热 卖 图 书 和 期 书 进行 分 页 展示 ， 其 运行 效果 图 如 图 15.28 所 示 。 
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图 15.28 特别 图 书 分 页 展示 


力 关键 技术 

在 特别 图 书 模块 中 ， 包 括 新 书 推荐 、 特 价 图 书 、 热 卖 图 书 、 期 书 和 试 读 5 个 子 选项 ， 在 这 5 个 子 模块 之 间 
的 跳 转 根据 的 是 超 链 接 参 数 t 传递 的 变量 值 ， 在 动态 文件 listsepbook.php 中 应 用 站 语句 进行 判断 ， 并 且 根 据 判 
断 的 结 者 果 为 模板 变量 赋值 ， 然后 在 模板 变量 中 输出 对 应 的 内 容 。listsepbook.php 文件 的 关键 代码 如 下 : 


i ; 
} elseif ($ GETIt] =— hotsell) { 
Snowtype= 热卖 图 书 '; 


Sandwhere = "ishotsell = 1"; 
} elseif ($_GET[t] — term’) { 
Snowtype 一 期 书 ; 
Sandwhere = "isterm = 1"; 
} elseif ($_GET[t] — ‘mrbook) { 
Snowtype =' 明 日 图 书 推荐 
Sandwhere = "ismrbookti = 1"; 
3 
Ssmarty->assign('gt'. $_GET[t]); 
->assign(nowtype'、 


Ssmarty- Snowtype); 
在 完成 特别 图 书 的 分 页 输出 时 ， 编 写 一 个 多 表 查 询 的 SQL 语句 ， 对 tb_bookinfo 和 tb_pub 两 个 数据 表 进 行 
查询 ， 其 使 用 的 SQL 语句 如 下 : 


S$sql = "select tb bookinfo.id, tb bookinfo.bookimg. tb bookinfo.about, tb bookinfo.browsertime. tb bookinfo.oldprice. tb bookinfo.newpri 
ool ool Ib odin witer DIDOor ito peitine th Deeit Raine th Lodo te vit ini Domib Loo Dt 
where tb_bookinfo.pubid = tb_pub.id and " . $andwhere . " order by tb_bookinfo.addtime desc"; 


PHP 开发 实战 1200 例 (第 I 卷 ) 


力 设计 过 程 


(1) 建立 listsepbook.php 文件 用 来 实现 业务 逻辑 。 在 该 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 查询 字符 串 


参数 t 的 值 ， 然 后 根据 该 值 决定 当前 页 面 要 显示 的 内 容 ， 并 构建 查询 语句 ， 最 后 使 用 分 页 类 的 pageData0 方 法 实 


现 分 


页 查询 ， 其 完整 代码 请 参考 本 书 光 盘 ， 这 里 不 再 袭 述 。 
(2) 建立 模板 页 listsepbook.phtml， 通 过 section 语句 分 页 输出 指定 类 别 下 的 图 书信 息 ， 其 关键 代码 如 下 : 
{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 
<br 
<div style="width:10096: height:180px"> 
<div style="width:2096: height10096: float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"><img src=" {$system[0].bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border: 1px solid #123456" /></a> 
<div> 
<div style="width:78%:; height10096: oatright text-align:left; font-size:13px"> 
<listyle="display:inline"><a href=" futil->baseUrl}/bookinfo-{Sbookinfos data[pbID] id} html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 : {$bookinfos.data[pbID].pubname}</li> 

<br><br> 

<li style="display:inline"> 作 者 : {Sbookinfos.data[pbID] writerj</i> 

<br><br> 

<li style="display:inline"> 上 架 时 间 : {Sbookinfos.data[pbID].addtimeltuncate:10:""}&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp: 出 版 时 


间 : {$bookinfos.data[pbID].pubtimeltruncate:10:""} &nbsp;&nbsp;&nbsp;&nbsp;&nbsp:&nbsp; 浏 览 次 数 : {$bookinfos.data[pbID].browsertime} &nbsp; 
次 <lli> 
<br><br> 
<li style="display:inline"> 市 场 价 :<img src=" {util->baseUrl}/img/mark_green gif” />&nbsp;<s> {util->moneyFormat 
PF=$bookinfos.data[pbID].oldprice}</s>&nbsp:S&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbspi&nbsp; 
<font color="#FF0000"> 会 员 价 : <img src="{futil->baseUrlj/img/mark_red.gif' />&nbsp; {util->moneyFormat 
p=$bookinfos.data[pbID].newprice}</font> 
<li> 
<br><br> 
<li style="display:inline"><a href=" {util->baseUrl}/cart-{$bookinfos.data[pbID].id}-add.html"><img 
src=" {util->baseUrl}/img/button_order.gif" border="0"/></a>&nbsp:&nbsp:&nbsp:&nbsp:<a 
href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID] id} .html"><img sre=" {util->baseUrl}/img/button_info.gif" border="0"/></a></li> 
<div> 
<div> 
<div style= "width:9596: height:S0px; border:1px solid #CCCCCC; textralign:left; line-height: 18px:; color:#990000; padding:5px"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
<div> 
{/section} 
{else} 
<div style="width:500px: height:80px: font-size:14px: color:#FF0000"> 
<img sre=" {util->baseUrl}/img/mark telllogin.gif’><br /> 
<strong> 对 不 起 ， 暂 无 新 书信 息 ! </strong> 
<div> 
{ 馈 


图 秘笈 心 法 


心 法 领悟 601: SQL 语句 中 的 多 表 查 询 。 
在 SQL 语言 中 ， 通 过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 用 “表明 .字段 名 ”表示 ， 这 样 可 以 避免 


因 表 之 问 字段 重 名 而 无 法 获知 该 字段 属于 哪个 表 。 在 where 子 句 中 多 个 表 之 间 所 形成 的 联动 关系 应 按 如 下 格式 
书写 : 


852 


表 1 字段 =- 表 2 字段 and 其 他 查询 条 件 
多 表 查 询 的 语法 如 下 : 
select 字段 名 from 表 1 表 2…… where 表 1 字段 = 表 2. 字段 and 其 他 查询 条 件 


高 级 | 
趣味 指数 : 走穴 直 契 ; 


图 实例 说 明 
为 了 能 够 让 读者 了 解 某 本 图 书 的 大 概 内 容 ， 吸 引 更 多 读者 购买 图 书 ， 在 制作 明日 科技 图 书 网 时 ， 将 图 书 斌 


读 作为 单独 模块 ， 其 运行 效果 如 图 15.29 所 示 。 


Ra 
a mm 
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八条 世 赤 T 吉 并 2 让 ， 部 KE 未 届 本 第 1 页 共 1 页 。 首页 上 一 页 下 一 页 尾 区 


15.29 ” 试 读 图 书展 示 


力 关键 技术 

实现 图 书 试 读 的 关键 技术 是 如 何 获取 到 试 读 文件 ， 本 实例 中 应 用 HTTP 方式 完成 试 读 文件 的 下 载 操作 ， 其 
中 关键 是 header0 函 数 的 应 用 。 有 关 应 用 HTTP 方式 进行 下 载 的 详细 讲解 请 参考 本 书 第 4 章 的 内 容 。 

在 本 项 目 中 ， 下 载 的 操作 在 upfiles\doc\download.php 文件 中 完成 ， 同 时 还 对 文件 被 下 载 的 次 数 进行 统计 ， 


其 关键 代码 如 下 : 
<?php 
Tequire_once ‘lzh.inc.php'; /包含 类 的 实例 化 文件 
$filename=$_GET['filename]; /获取 文件 名 称 
Srid=S$_GET[rid]; /获取 文件 的 记 
$system = $adminDB->executeSQL("update tb_read set downtimes = downtimes+1 where id-'Srid". $connID): /执行 更 新 操作 
if(file_ exists($filename)—false){ /判断 上 传 文件 是 否 存 在 
echo "<script>alert( 对 不 起 ， 本 站 暂时 停止 该 文件 下 载 !"):history.back0:</script>"; 
exit; 
} 
S$fp=fopen($filename."r"): /打开 上 传 文件 
header("Content-type:application/octet-stream'"): 


:filename=". $filename): 
echo fread($fp,filesize($filename)): // 读 取 上 传 文件 内 容 
felose($fp); /关闭 文件 


图 设计 过 程 

图 书 试 读 模块 对 明日 科技 图 书 网 站 中 所 有 可 以 试 读 的 图 书 进行 分 页 展示 。 

(1) 新 建 listreadbook php 文件 ， 完 成 所 有 试 读 图 书 的 分 页 查询 操作 。 首 先 ， 通 过 $_GET 全 局 数组 接收 查 
询 字符 串 page 的 值 ， 该 值 用 来 指定 当前 页 面 要 显示 的 内 容 。 然 后 ， 构 建 查询 语句 ， 通 过 分 页 类 的 pageData0 方 
法 获得 分 页 数据 。 最 后 ， 将 查询 结果 赋 给 模板 变量 ， 并 且 指 定 模板 页 ， 具 体 实现 代码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


第 15 章 ”综合 应 用 


/设置 页 面 的 最 后 更 新 日 期 (用 格林 威 治 时 间 表示 )， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: " . gmdate("D, d MY Hii:s") . "GMT"): 


header("Cache-Control: no-cache. must-revalidate"); /控制 页 面 不 使 用 缓存 

header("Pragma no-cache"); /参数 与 以 前 的 服务 器 兼容 ， 即 兼容 HTTP1.0 协议 
header("Content-type: application/file"): /输出 类 型 

header("Content-Length: 227685"): /文件 长 度 


header("Accept-Ranges: 。 bytes"): /| 接受 的 范围 单位 
// 缺 省 时 文件 保存 对 话 框 中 的 文件 名 称 
header("Content— Disposition: attachment: filename=$filename"); /实现 下 载 


(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
De 401 Unauthorized’); 


header('status: 401 Unauthorized"): 
> 


(4) 实现 HTTP 下 载 。 
header("Content-type: application/x-gzip"); 
header("Content-Disposition: attachment; filename= 文 件 名 "); 
header("Content-Description: PHP3 Generated Data"); > 
HTTP 标 头 有 很 多 ， 这 里 只 介绍 下 载 的 HTTP 标 头 ， 其 代码 如 下 : 
header('Content-Disposition: attachment; filename="filename"); 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 filename， 即 将 filename 蔡 换 为 要 下 载 的 文件 。 


实例 说 明 


为 了 让 浏览 者 能 够 更 加 细致 地 了 解 所 查询 图 书 的 详细 信息 ， 并 能 够 对 所 选 购 的 图 书 进行 评论 ， 还 需要 通过 
图 书 详细 信息 页 将 图 书信 息 展示 出 来 ， 效 果 如 图 15.30 所 示 。 
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图 15.30 图 书 详细 信息 展示 
图 关键 技术 


图 书 详细 信息 展示 页 中 应 用 的 技术 如 下 : 
(1) 数据 库 的 连接 、 操 作 类 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


第 15 章 “综合 应 用 
也 bookinfo .smalltypeid 一 tb_ smalltypeid and tb bookinfo id 一 ”. Sbid ."" $connID): /获得 图 书信 息 
S$bookinfo): 


$smarty->assign(bookinfo' 
代码 说 明 : 
@ 这 里 将 用 户 所 浏览 过 的 图 书 ID 用 字符 “@” 连 接 保存 到 
SESSION 中 。 = 
@ 函数 array_push0 用 来 将 元 素 添加 到 指定 的 数组 中 。 , Em 
(2) 为 了 帮助 读者 选 购 套 系 图 书 ,制订 学 习 流程 ， 在 制作 明 : Ee 
日 科技 图 书 网 的 图 书 详细 信息 页 时 ， 增 加 图 书 组 合 购买 功能 ,其 | svariwes on 
效果 如 图 15.31 所 示 。 ITTTTTTTT 


在 数据 库 中 使 用 tb book 表 的 bookids 字段 将 组 合 购买 图 书 的 图 1531 图 书 组 合 购买 
ID 用 字符 “@” 连 接 ， 在 bookinfo.php 页 面 中 ， 首 先 使 用 函数 
explode0 将 组 合 ID 保存 到 数组 中 ， 然 后 使 用 for 循环 语句 遍历 该 数组 ， 根 据 该 数组 元 素 查 询 出 所 有 组 合 图 书信 
息 并 将 图 书信 息 保存 到 $arrayZhBooks 数组 中 ， 最 后 将 该 数组 传递 给 模板 ， 在 模板 中 通过 section 语句 输出 所 有 
组 合 图 书信 息 ， 其 关键 代码 如 下 : 
$arrayBookids = explode((@', $bookinfo[O]["bookids']): // 使 用 字符 “@” 分 割 组 合 图 书 ID 
SarrayZhBooks = arrayO; 


S$zhIDs = Sbookinfofolfbid1.Q@' 
for ($i = 0; $i < count($arrayBookids); $i++) { // 获 得 组 合作 图书 信息 
if (SarrayBookids[$i] (=") { 
Es SadminDB->executesQL("select 这 bookname, bookimg from tb_bookinfo where id=" . SarayBookids[Si] . "™, SconnID); 
wy push(SarrayZhBooks, $tmpBookinfo); 
SzhlDs = = $tmpBookinfo[o]['id] . '@’; 


>assign('zhIDs', $zhIDs); 

S$smarty->assign('arrayZhBooks', $arrayZhBooks); 

(3) 在 图 书 详细 信息 页 加 入 读者 评论 功能 ， 有 助 于 网 站 经 营 者 分 析 图 书 的 价值 ， 从 而 确定 图 书 在 站 点 中 的 
择 放 位 置 ， 实 现 评 论 功能 的 过 程 如 下 : 

@ 在 图 书 详细 信息 展示 的 模板 页 中 创建 form 表单 ， 将 用 户 评论 提交 到 bookinfo.php 页面 ， 添 加 到 指定 的 
数据 表 中 。 

@ 在 bookinfo php 页 面 中 读 取 图 书评 论 信息 ， 并 且 将 评论 信息 在 模板 页 bookinfo .phtml 中 输出 。 同 时 在 模 
板 页 中 为 图 书评 论 信息 创建 “删除 ” 超 链接 ， 使 评论 的 发 布 者 可 以 删除 自己 的 评论 。 

本 实例 的 完整 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 ， 这 里 不 再 资 述 。 


图 秘笈 心 法 


心 法 领悟 603: 内 容 简介 和 图 书目 录 之 间 的 切换 。 

在 图 书 详细 信息 展示 的 模板 页 中 , 通过 onmouseover 事件 调用 JavaScript 脚本 中 的 changeTab10 方 法 实现 在 
内 容 简 介 和 图 书目 录 之 间 的 切换 ， 其 原理 是 通过 onmouseover 事件 调用 JavaScript 脚本 中 的 方法 ， 控 制 <div> 标 
签 样式 的 隐藏 和 展开 。 

应 用 的 过 程 中 ， 唯 一 需要 改动 的 就 是 人 lename， 即 将 flename 替换 为 要 下 载 的 文件 。 


图 实例 说 明 
在 明日 科技 图 书 网 的 主页 中 有 一 个 新 闻 公 告 展 示 模 块 ， 用 于 展示 明日 科技 网 站 发 
布 的 新 闻 公 告 信息 ， 其 运行 效果 如 图 15.32 所 示 。 图 15.32 ”新闻 公告 


857 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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在 本 实例 中 ， 运 用 了 两 种 截取 中 文字 符 串 的 方法 。 第 一 种 是 Smarty 模板 中 的 truncate 方法 ， 它 虽然 可 以 对 
中 文字 符 串 进行 截取 ， 但 是 同样 可 能 会 出 现 乱 码 的 问题 ， 第 二 种 是 自 定义 的 方法 msubstr0， 可 以 防止 截取 中 文 
字符 串 时 出 现 乱 码 ， 在 使 用 时 需要 传递 3 个 参数 ， 指 定 截取 的 字符 串 、 截 取 的 开始 位 置 和 截取 的 长 度 。 


15.5 站 内 搜索 


搜索 功能 是 一 个 很 重要 上 且 常见 的 功能 。 一 个 好 的 搜索 引擎 能 给 用 户 的 使 用 带 来 方便 。 本 节 将 以 明日 科技 图 
书 网 站 中 的 一 般 搜 索 和 高 级 搜索 为 例 ， 讲 解 搜 索 功能 的 实现 方法 。 


i 
图 实例 说 明 


在 明日 科技 图 书 网 站 的 头 文件 中 ， 设 计 了 一 个 查找 图 书 的 文本 框 ， 其 实现 的 就 是 一 般 搜索 的 功能 。 在 本 实 
例 中 ， 按 图 书 名 称 进行 搜索 ， 输 入 PHP 关键 字 ， 单 击 “查找 图 书 ” 按 钮 ， 将 输出 如 图 15.33 所 示 的 内 容 。 
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图 15.33 ”查找 图 书信 息 


图 关键 技术 

在 一 般 搜索 功能 中 ， 关键 技 术 是 应 用 explode0 函 数 对 查询 的 关键 字 进 行 拆 分 ， 返 回 一 个 数组 。 然 后 通过 for 
循环 语句 读 取 这 个 数组 中 的 元 素 。 最 后 ， 定 义 select 查询 中 的 where 子 句 ， 以 数组 中 的 元 素 值 为 like 模糊 查询 
的 条 件 ， 其 关键 代码 如 下 : 


SarrayKeyWord = explode(' $keyWord): /1/ 使 用 空格 对 查询 的 关键 字 进 行 拆 分 
Swhere 一 /定义 变量 
$=0; 
for($i=0; $i<count($arrayKeyWord): Si+H){ /| 循环 读 取 查询 关键 字数 组 中 的 元 素 
if($arayKeyWord[$i]!="){ / 潮 断 数组 元 素 的 值 是 否 为 空 
if($j>0){ // 如 果 变量 值 大 于 0 
Swhere = " or ": // 定 义 where 变量 的 值 
} 
$where =" tb_bookinfo.bookname like '%".$arrayKeyWord[$i]."%'": /定义 变量 的 值 ， 即 定义 查询 语句 的 where 子 句 
Sitt; 
} 
} 
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如 果 参 数 limit 是 负数 ， 则 返回 除 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 


高 级 i 
字 I | 
实例 606 超 休 指数 :页 机 本 页 


图 实例 说 明 


在 明日 科技 图 书 网 站 的 高 级 搜索 功能 中 ， 可 以 输入 图 书 名 称 关键 字 、 作 者 、 出 版 社 、 类 别 和 出 版 时 间 ， 根 
据 这 些 内 容 进行 综合 查询 ， 高 级 搜索 的 运行 效果 如 图 15.34 所 示 。 


知 当 页 的 位 塞 ， 朋 日 网 上 书后 )》 责 级 所 过 


ES 《二 国 书 和 各 和光 F 孔 ， 志 个 关键 字 之 闭 用 空 六 分 吉 ) 
作者 ， E23 《 * 请 入 作者 名 各 关键 子 ， 近 作者 名 称 卉 本 区 也 ) 
上 出 版 六 | 大 Ra 和 到 


站 ET | 
出版 时 站， [255” 司 年 人 司 5-- 双 -- [mm 司 和 [同月 
国 到 


图 15.34 ”高 级 搜索 表单 


力 关键 技术 


(1) 应 用 Smarty 模板 中 的 {ldelim} frdelim} 标 签 在 Smarty 模板 页 中 直接 编辑 JavaScript 脚本 语句 。 
(2) 在 JavaScript 脚本 中 应 用 jQuery 技术 编写 图 书 类 别 展示 的 二 级 联动 菜单 ， 其 关键 代码 如 下 : 


<script src=" {util->baseUrl}/js/jquery.js"></script> <!-- 载 入 jQuery 库 -> 
<scriptlanguage="javascript" > 
S$(document) .ready( 
functionO {ldelim} 
S$("#bigtypeid").change(function() {ldelim} 
$.get(" {util->baseUrl} /getstype.php?stid="+$("#bigtypeid").valO, null, function(data) {1delim} 
"“#smalltypeid").emptyO; 
S$S("#smalltypeid").append(data); 
{rdelim}); 
{rdelim}); 
{rdelim} 
script> 
其 中 调用 getstype.php 文件 ， 定 义 图 书 类 别 中 子 类 的 下 拉 列 表 框 值 ，getstype.php 文件 的 代码 如 下 : 
<?php 
Tequire_once ' lzh.inc.php': /包含 配置 文件 
$small SadminDB->executeSQL("select id, typename from tb_smalltype where bigtypeid=".$_GETT['stid]."", SconnID): 


for($i= 0; $i < count(Ssmalltypes): Sit+){ // 将 从 数据 库 中 读 取 的 数据 添加 到 下 拉 列 表 的 选项 中 
S$data .= "<option value=\"".$smalltypes[$i]["id"]."\">".iconv(‘gbk'. ‘utf-8', $smalltypes[$i]['typename’])."</option>"; 
} 


echo $data; // 输 出 变量 值 ， 即 输出 下 拉 列 表 的 值 
(3) 应 用 Smarty 模板 中 的 html_options0 方 法 自 定义 函数 设置 日 期 的 下 拉 列 表 框 值 ， 其 部 分 代码 如 下 : 
<select name=—" 


fyear> 
<option value=" selected>- 请 选择 -</option> 
{html_options options = $arrayYear} 
</select>&nbsp: 年 
<select name="fimonth"> 
<option value=" selected>- 请 选择 -</option> 
{html_options options = $arrayMonth} 
</select>&nbsp: 月 &nbsp:-&nbsp:-&nbsp: 到 


(4) 定义 高 级 搜索 的 SQL 语句 ， 充 分 发 挥 where 子 句 的 作用 ， 通 过 多 表 查 询 完成 高 级 搜索 的 功能 。 


861 


加 载 中 
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(4) 在 search.phtml 模板 页 中 ， 应 用 section 语句 分 页 输出 查询 结果 ， 代 码 请 参考 本 书 光盘 。 
图 秘笈 心 法 


心 法 领悟 606: jQuery 框架 。 

jQuery 由 美国 人 John Resig 创建 ， 至 今 已 吸引 了 来 自 世界 各 地 的 众多 JavaScript 高 手 加 入 其 团队 。jQuery 
是 继 prototype 之 后 又 一 个 优秀 的 JavaScript 框架 ， 其 宗旨 是 WRITE LESS，DO MORE， 即 写 更 少 的 代码 ， 做 更 
多 的 事情 。 它 是 轻 量 级 的 js 库 〈 压 缩 后 只 有 21KB) ， 这 是 其 他 js 库 所 不 及 的 。 它 兼容 CSS3 以 及 各 种 浏览 器 
(IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+ 等 ) 。 

jQuery 是 一 个 快速 的 、 简 洁 的 javaScript 库 ， 使 用 户 能 更 方便 地 处 理 HTML documents、events、 实 现 动画 
效果 ， 并 且 方 便 地 为 网 站 提供 AJAX 交互 。 

应 用 jQuery 技术 的 前 提 条 件 是 必须 在 项 目 中 载 入 jQuery 库 ， 否 则 无 法 调用 其 中 的 方法 。 


15.6 购 物 车 


购物 车 是 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ”， 为 用 户 在 网 上 购物 提供 了 很 大 的 方便 ， 不 用 担 
心 一 次 购买 多 个 商品 时 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 所 选 商品 放 入 购物 车 中 ， 等 选 购 完成 后 一 起 结算 ， 
购物 车 是 电子 商务 类 网 站 中 一 个 必 不 可 少 的 功能 。 本 节 将 以 明日 网 上 书店 中 的 购物 车 为 模板 ， 详 细 讲 解 购物 车 
的 实现 过 程 。 


实例 607 趣味 指数 : 二 食 食 从 | 


图 实例 说 明 


对 于 电子 商务 类 网 站 来 说 ， 安 全 、 稳 定 的 购物 车 模块 是 非常 重要 的 ， 该 模块 直接 关系 到 交易 是 否 能 够 顺利 
进行 。 为 了 提高 代码 的 可 移植 性 ， 在 制作 明日 科技 书店 购物 车 时 ， 将 购物 车 抽象 成 类 ， 封 装 到 library\Cartphp 
文件 中 。 购 物 车 功能 的 运行 效果 如 图 15.35 所 示 。 

富 购物 沪 性 


BB 仙人 人 有 DO mst#x 
” 9 nvmes 六 ET 


5.35 ”购物 车 的 运行 效果 


图 关键 技术 


在 购物 车 类 的 封装 中 ， 应 用 最 多 的 就 是 explode0 函 数 和 implode0 函 数 。 
(1) explode0 函 数 ， 将 字符 串 用 指定 的 子 串 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 。 在 购物 车 类 的 addCartO 


方法 中 ， 应 用 explode0 函 数 将 ID 串 用 @ 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 其 关键 代码 如 下 : 
SarrayIds = explode((@' $this->idStr); /将 友 串 用 @ 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 
(2) implode0 函 数 ， 将 指定 数组 中 的 所 有 元 素 使 用 特定 的 字符 进行 连接 形成 新 的 字符 串 ， 其 语法 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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的 ID 相同 的 ID 号 ， 则 使 用 函数 unsetO 将 数组 元 素 销毁 ， 然 后 再 将 数组 中 所 有 元 素 重 新 用 字符 @ 连 接 成 商品 外 
串 ， 这 样 就 可 以 实现 将 指定 的 商品 从 购物 车 中 移 除 的 操作 。 
(5) 使 用 changeNum0 方 法 更 改 购物 车 中 商品 的 数量 ， 其 代码 如 下 : 


function changeNum($goodsId, $goodsNum){ 
SarrayIds = explode(@'. $this->idStr); // 将 商品 DD 串 用 @ 分 割 成 数组 
$arrayNums = explode('@’, $this->numStr); // 将 商品 数量 串 用 @ 分 割 成 数组 
for($i = 0; $i < count(SarrayIds); SiH+){ /遍历 商品 人 D 串 
if ($arrayIds[$i] — S$goodsId){ /如 果 查 找到 要 更 改 的 ID 
S$arrayNums[$i] = $goodsNum; /更 改 数量 

} 

Sthis->idStr = implode('@), SarrayIds); // 重 新 合并 成 人 D 串 
Sthis->numStr = implode((@', SarayNums); /重新 合并 成 数量 串 


} 
changeNum0 方 法 中 包含 两 个 参数 ， 分 别 为 要 更 改 的 商品 了 DP 号 和 要 更 改 的 数量 。 在 该 方法 内 部 ， 首 先 使 用 
函数 explode0 将 商品 卫 串 和 商品 数量 串 用 @ 进 行 分 割 ， 并 将 分 割 的 字 串 分 别 保存 到 数组 中 ， 然 后 通过 for 循环 
语句 遍历 商品 了 D 数组 ， 在 其 中 查找 要 更 改 数量 的 商品 人 D， 查 找到 后 ， 将 新 数量 值 赋 给 数量 串 中 对 应 的 数组 元 
素 , 最 后 使 用 函数 implode0 将 商品 卫 数组 和 商品 数量 数组 中 的 所 有 元 素 分 别 重 新 用 字符 @ 进 行 连接 , 组 成 新 的 
商品 ID 串 和 商品 数量 串 。 
(6) 通过 Cart 类 的 setCartNull0 方 法 ， 清 空 购物 车 中 的 商品 。 实 现 清空 购物 车 中 商品 的 操作 ， 只 需 将 商品 


fanction setCartNullO{ 
S$this->idStr ="; /清空 商品 人 D 串 
Sthis->numStr ="; /清空 商品 数量 串 


} 
(7) 通过 购物 车 类 中 的 方法 完成 对 商品 ID 串 和 商品 数量 串 的 操作 后 ， 还 需要 定义 两 个 方法 ， 分 别 用 来 获 
取 商 品 ID 串 和 商品 数量 串 ， 其 代码 如 下 : 
function getIdStrO{ // 获 得 购物 车 的 商品 ID 串 
return S$this->idStr; 
} 
function getNumStrO{ /获得 购物 车 的 商品 数量 串 
Teturn S$this->numStr: 


} 
以 上 讲解 了 明日 科技 书店 购物 车 功能 的 Cart 类 的 属性 和 主要 方法 ， 其 存储 于 library\Cart.php 文件 中 。 


图 秘笈 心 法 


心 法 领悟 607: 解析 购物 车 类 中 的 商品 卫 串 和 数量 串 。 
购物 车 类 中 的 商品 人 D 串 和 商品 数量 串 是 指 用 字符 @ 连 接 的 多 个 商品 的 ID 号 和 数量 值 ， 其 目的 是 使 用 一 个 
变量 或 者 数据 表 中 的 一 个 字段 存储 多 个 商品 的 ID 或 数量 。 


图 实例 说 明 


购物 车 的 主要 功能 是 保留 用 户 选 择 的 商品 信息 。 用 户 可 以 在 购物 车 内 设置 选 购 商品 的 数量 、 显 示 选 购 商品 
的 总 金额 ， 还 可 以 进行 清除 选择 的 全 部 商品 信息 、 重 新 选择 商品 信息 等 操作 。 在 实例 607 中 已 经 讲解 了 购物 车 
类 的 实现 过 程 ， 本 实例 将 在 此 基础 上 介绍 购物 车 的 页 面 设 计 和 功能 实现 ， 其 中 明日 科技 书店 的 购物 车 运行 效果 
如 图 15.36 所 示 。 
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$_SESSION[toUrl] = 'getbuyuserinfo html': 
。 (8) 在 views 文件 夹 下 新 建 cart.phtml 模板 页 ， 完 成 购物 车 页 面 的 设计 。 
力 秘笈 心 法 


心 法 领悟 608: 判断 指定 的 数据 是 否 是 正 整数 。 

判断 指定 的 数据 是 否 是 正 整数 ， 应 用 到 3 个 函数 : is_numericO、intval0 和 floor0。 

is_numeric0 函 数 ， 检 测 变量 是 否 为 数字 或 者 数字 字符 串 ， 如 果 是 则 返回 TRUE， 和 否则 返回 FALSE。 

intval0 函 数 ， 获 取 变 量 的 整数 值 。 

floor0 函 数 ， 利 用 舍 去 法 获取 变量 的 整数 值 。 

在 让 条 件 语句 中 ， 判 断 is_numeric0 函 数 的 返回 值 是 否 为 TRUE， 判 断 intval0 函 数 的 返回 值 是 否 大 于 0， 判 
断 floor0 函 数 的 返回 值 与 变量 值 是 否 相等 。 当 满足 is_numericO 函 数 的 返回 值 为 TRUE，intvalO 函 数 的 返回 值 大 
于 0，floor0 函 数 的 返回 值 与 变量 值 相等 时 ， 说 明 变 量 是 正 整 数 ， 否 则 说 明 不 是 正 整数 ， 其 应 用 方法 如 下 : 


if(!is ee intval($changenum) < 一 0 || floor($changenum) '= $changenum) { 
echo "<script>alert(' 购 买 图 书 的 数量 只 能 为 正 整 数 ! :</script>"; 


i 为 要 验证 的 变量 。 


15.7 ”图书 订单 处 理 


为 了 方便 用 户 购买 图 书 ， 促 进 图 书 销售 ， 在 开发 明日 科技 图 书 网 时 特别 设立 图 书 订单 处 理 模 块 ， 通 过 该 模 
块 用 户 可 以 方便 地 订购 图 书 并 进行 在 线 支 付 。 本 节 将 对 明日 科技 书店 图 书 订单 处 理 模 块 进行 讲解 。 


力 实例 说 明 


为 了 能 够 将 用 户 所 购买 的 图 书 顺利 邮寄 到 用 户 手中 ， 在 用 户 选择 好 购买 的 图 书后 还 需要 填写 收 货 人 信息 ， 
明日 科技 图 书 网 用 于 填写 收 货 人 信息 的 页 面 如 图 15.37 所 示 ， 在 该 页 面 中 ， 用 户 需 要 填写 个 人 的 真实 联系 信息 、 
收 货 方式 等 内 容 ， 如 果 需 要 发 票 ， 还 需要 填写 发 票 抬头 。 


《Cn 读 革 已 怕 全 人 真实 扒 扣 ) 
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15.37 填写 收 货 人 信息 的 页 面 
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Srecpay ='20"; 
} elseif (Srect —'4) { 
Srecpay ="30'; 


} 
$ SESSIONT'recuserinfo'I['recpay’] = 


Srecpay; 
echo "<script>window.location.href=" . Sutil->baseUrlO . "/deforder.html':</script>"; // 重 新 定向 到 deforder.html 页 面 
exitO; 
i 
Tequire_once 'footer.php'; 
力 秘笈 心 法 


心 法 领悟 609: 在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 。 
在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 ， 应 用 的 是 Smarty 模板 中 的 $smarty.session 标签 。 首 先 ， 在 
PHP 动态 页 中 ， 定 义 SESSION 变量 。 其 格式 如 下 : 


$_SESSION[Yrecuserinfo'][username'] = $_POST[username]; 
$_SESSION[Yrecuserinfo']['sex]=$_ POST[sex]; 


然后 ， 在 Smarty 模板 页 中 ， 通 过 如 下 方法 获取 SESSION 变量 的 值 : 


高 级 | 
趣味 指数 : 会合 傅 闪 | 


实例 610 


力 实例 说 明 
用 户 填 写 完 收 货 人 信息 后 将 进入 订购 信息 确认 页 面 ， 如 图 15.38 所 示 ， 在 该 页 面 中 可 以 查看 并 确认 用 户 所 
订购 图 书 的 名 称 、 单 价 、 总 价格 和 收 货 人 的 信息 。 
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图 15.38 ”确认 订购 信息 


图 关键 技术 

确认 订购 信息 功能 的 实现 , 首先 应 用 的 是 explode0 函 数 对 商品 ID 串 和 商品 数量 串 中 的 数据 进行 读 取 , 然后 
根据 返回 的 数组 元 素 值 ， 从 数据 库 中 读 取 图 书信 息 ， 完 成 图 书 价格 的 汇总 。 

在 deforderphtml 模板 页 中 ,通过 section 语句 循环 输出 用 户 购买 的 图 书信 息 ， 并 且 通 过 $smarty.session 标签 
输出 收 货 人 的 信息 。 上 述 方法 都 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 不 再 袭 述 。 
图 设计 过 程 


(1) 为 了 使 图 书 订购 流程 的 业务 逻辑 更 加 方便 ， 将 购物 车 和 收 货 人 的 信息 保存 到 session 中 ， 所 以 显示 用 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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网 站 中 提交 的 数据 ， 并 且 将 数据 赋 给 模板 变量 ， 在 模板 页 中 通过 form 表单 将 数据 提交 到 支付 宝 的 网 站 中 。 
defpay.php 动态 页 的 关键 代码 如 下 : 


<?php 

Tequire_once ‘header.php’; 

St=$ GETItT: 

f(st— 'qyzh) { 
Spaytype = ' 企 业 账 户 汇款 '; 
SalertType ='0'; 

jelseif ($t — 'zfb") { 
Spaytype = 他 宝 在 线 支付 
Salt 

} elseif ($t— 
$paytype = 工行 在 线 支付 ': 
SalertType = 35 


} 

/省 略 了 部 分 代码 

if ($alertType —'2) { 
$smarty->assign('orderid', $ orderNo]); 
$smarty->assign('ydType', EXPRES: 
$smarty->assign('ydPrice’, $ es 
S$smarty->assign(‘bookPrice', $_SESSION['Yecuserinfo][bookprice]): 


} 
在 defpay.phtml 模板 页 中 ， 输 出 订单 的 确认 信息 ， 创 建 向 支付 宝 网 站 中 提交 数据 的 form 表单 ， 判 断 当 模 板 
变量 $alertType 的 值 等 于 2 时 ， 完 成 向 支付 宝 网 站 中 提交 数据 的 操作 ， 其 关键 代码 如 下 : 


<form name="form zfb" method="post" action="http://221.8.65.77/zfb/index.php" target=" blank"> 


<input type="hidden" name="ydPrice" value=" {util->moneyFormat p=$ydPrice}"> 
<input type="hidden" name="price" value=" {util->moneyFormat p=$bookPrice}"> 
</form> 
<a {if $alertType — 
href="javascript: jet( 他 的 订购 信息 已经 保存 ; 请 到 指定 银行 汇款 !):" 
{elseif $alertType —'1'} 
href="javascript:alert( 您 的 订购 信息 已 经 保存 ,请 到 邮局 邮 款 !);" 
{elseif $alertType =— '2'} 
href="javascript:form zfb.submitO:;" 
{elseif $alertType =— '3'} 
href="javascript:toicbe.submit();" 


a ste=" {util->baseUrl}/img/button_defpay.gif" border="0" /></a> 
图 秘笈 心 法 

心 法 领悟 611: 支付 宝 在 线 支付 。 

声明 : 这 里 讲解 的 是 通过 PHP 实现 电子 商务 网 站 与 支付 宝 进行 交互 的 方法 ， 其 中 涉及 到 的 支付 宝 提供 的 参 
数 和 设置 都 是 虚拟 的 ， 真 实 的 参数 将 在 实际 的 运作 中 由 支付 宝 提供 。 


图 实例 说 明 


在 选择 支付 方式 页 面 中 ， 单 击 工行 在 线 支 付 的 “支付 ” 超 链接 ， 将 跳 转 到 如 图 15.42 所 示 的 页 面 ， 输 出 本 
次 图 书 订购 的 订单 号 、 支 付 方式 和 需要 支付 的 总 金额 。 

如 果 单 击 图 15.42 中 的 “已 经 确认 订购 信息 按 选 择 支 付 方式 支付 ”按钮 ， 将 跳 转 到 工行 在 线 支付 页 面 ， 如 
图 15.43 所 示 。 
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图 15.42 支付 宝 在 线 支付 图 15.43 工行 在 线 支付 


图 关键 技术 

工行 在 线 支付 功能 的 实现 主要 根据 工行 提供 的 在 线 支付 的 接口 ， 将 订单 中 的 数据 以 表单 的 形式 提交 到 工行 
指定 的 网 址 中 。 详 细 的 参数 设置 可 以 参考 工行 提供 的 文档 说 明 书 和 实例 程序 。 

在 实现 与 工行 接口 的 连接 之 前 ， 首 先 要 从 工行 提供 的 说 明 书 中 找到 下 面 两 个 文件 : 开发 API 接口 
\LIB\windowsvwin32\infosecapi.dll (XP 系统 使 用 的 文件 ) 和 开发 API 接 口 ASP\ICBCEBankUtil.dll， 并 将 其 复制 
到 系统 文件 夹 下 的 WINDOWS\system32 下 ， 在 运行 命令 中 输入 regsvr32 ICBCEBankUtil.dll， 加 载 服务 。 

通过 PHP 实现 网 站 与 工行 接口 交互 的 方法 如 下 : 

首先 , 通过 com 类 中 的 init0 方 法 对 订单 签名 数据 和 商城 的 公 钥 进行 加 密 处 理 ， 并 且 将 指定 的 数据 以 表单 的 
形式 提交 到 工行 指定 的 页 面 中 ， 其 关键 代码 如 下 : 

$src="ICBC PERBANK B2C1.0.0.0".$infomer["merid"].$infomer["meracct"l]. $returnaddress."HS".$ddnumber.$amount."0010".$nowtime."0"; 

Scom=new com(ICBCEBANKUTIL.B2CUtil); 

Sre=$com->init("c:\WINDOWS\user.crt","d: \user.crt","d: \user.key","00"); 

S$ssrc=$com->signC($src, strlen(Ssrc)): // 订 单 签名 数据 


Src=$com->verifySignC($sre,strlen($src), $ssrc, strlen($ssre)); 
S$cert=$com->getCert(1); /商城 证 书 公 和 钥 


完成 订单 签名 数据 和 商城 证 书 公 钥 的 加 密 处 理 后 ,将 商户 的 测试 证 书 存储 到 c:\WINDOWS 目录 下 ,设置 商 
户 的 私 钥 口 令 为 00。 

然后 ， 创 建 form 表单 ， 将 指定 的 数据 提交 到 工行 指定 的 网 站 中 。 
图 设计 过 程 

工行 在 线 支付 的 操作 同样 由 defpay.php 和 defpay.phtml 两 个 文件 组 成 。 

(1) 在 defpay.php 动态 页 中 ， 判 断 如 果 选 择 的 是 工行 在 线 支付 ($alertType = '3') ， 则 定义 向 工行 在 线 支 
付 网 站 中 提交 的 数据 ， 并 且 将 数据 赋 给 模板 变量 ,在 模板 页 中 通过 form 表单 将 数据 提交 到 工行 在 线 支 付 的 网 站 
中 。 在 defpay.php 动态 页 中 ， 有 关 工 行 在 线 支 付 的 关键 代码 如 下 : 

<?php 


ire_once ‘header.php’; 

St=$ GETIt; 

if($t—'qyzh) { 
Spaytype = 企业 账户 汇款 '; 
S$alertType = '0'; 

jelseif ($t =— ‘zfb) { 
Spaytype== 支付 宝 在 线 支付 
SalertType = 2'; 


} 
/省 略 了 部 分 代码 
if ($alertType —'3) { 
SmerInfo = $adminDB->executeSQL("select merid, meracct fom tb_system where mark = 1", SconnID): 
Smerid = $merInfo[O]['merid"]: 
Smeracct = $merInfofOlf'meracctl: 
SmerURL = http://www.mrbooks.cn'; 
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管理 员 登 录 人 


用 Pn 


15.44 后台 管理 系统 登录 


图 关键 技术 


在 后 台 管理 系统 登录 功能 实现 过 程 中 ， 应 用 JavaScript 脚本 调用 xym.php 文件 完成 验证 码 的 输出 操作 。 在 
xym.php 文件 中 ， 应 用 文件 系统 函数 库 中 的 函数 将 指定 的 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ， 其 代码 如 下 : 


Snum=$_GET[num]; // 获 得 传递 的 数字 
Saddress="img/code/". Snum.".gif”; // 获 取 对 应 图 片 地 址 
Sfp=fopen($address,"r"); /打开 对 应 的 图 片 

echo fread($fp,filesize($address)); // 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 


felose($fp); /关闭 打开 的 图 片 
有 关 六 件 系统 函数 的 应 用 可 以 参 基本 书 第 4 齐 的 内 容 ， 这 里 不 再 化 过 。 
图 设计 过 程 
明日 科技 图 书 网 后 台 登 录 页 面 的 制作 过 程 主要 包括 登录 表单 的 设计 和 登录 信息 验证 。 


(1) 后 台 用 户 登 录 表 单 的 UI 是 通过 HTML 语言 的 input 标签 实现 的 ， 并 通过 JavaScript 实现 图 片 验证 码 ， 


admin-login.phtml 的 关键 代码 如 下 : 
<form name="form _login" method="post" action=" {util->baseUrl}/admin-login.php" onsubmit="retum chkinputadmin(this)"> 
<div style="width:300px: height:200px: text-align:left"> 
用 户 名 : <input type="text" name="anc" size="22" class="input" /><br /><br /> 
密码 : <input type="password" name="pwd" size="22" class="input" /><br /><br /> 
验证 码 ，<input type="text" name="xym" size="8" class="input" /><input type="hidden" value="" name="xyml"> 
‘<script language="javascript"> 
var num1=Math.round(Math.random()*10000000): 
var num=num1 .toString().substr(0,4); 
document write("<img name=codeimg4 sre=xym.php?num="+num.substr(0,1)+">"); 
document.write("<img name=codeimgs src='xym.php?num—="+num.substr(1,1)+">"); 
document.write("<img name=codeimg6 src=xym.php?num="+num.substr(2,1)+">"); 
document.write("<img name=codeimg7 src=xym.php?num="+num.substr(3,1)+">"); 
form login.xyml.value=nunl 
function code_10 {ldelim} 
var numl=Math_.round(Math random0*10000000): 
var num=numl.toString().substr(0.4): 
document.codeimg4.src="xym.php?num="+num.substr(0.1): 
document.codeimgs.src= "xym.php?num="+num.substr(1.1): 
document.codeimg6.src="xym.php?num—="+num.substr(2.1); 
document.codeimg7.sre="xym.php?num="+num. substr(3.1); 
form login.xyml.value=num; 
{rdelim} 
</script> 
<a href="javascript:code_10" class="al"> 看 不 清 </a> 
<input type="submit" value=" 登 录 " 广 &nbsp:&nbsp:<input type= "reset" value=" 重 置 " /> 
</div> 
</form> 
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(2) 在 admin-login.php 文件 中 完成 对 用 户 名 和 密码 的 验证 ， 如 果 用 户 名 和 密码 不 正确 ， 则 提示 登录 失败 ; 
否则 将 登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 跳 转 到 后 台 管 理 系 统 的 admin-index.php 页 面 ， 其 代码 如 下 : 


require_once ‘zh inc.php’; 


让 (isset($_ POST[anc]) && $ POST[anc] =") { 1/ 判断 用 户 是 否 提交 了 表单 
if ($adminDB->executeSQL("select id, useme from tb_user where usemce=" . $ POST[anc] . " and pwd=" . md5(trim($_ POST['pwd"]) . " 
usertype=1", $connID)) { /根据 用 户 昵称 和 密码 查询 管理 员 
if(isset($_SESSION['anc'D)) { /如果 查 询 到 则 说 明 登 录 成 功 ， 这 时 将 管理 员 昵称 保存 到 SESSION 中 


unset(s_SESSION[anc]): 


} 
$ NI $ POSTTanc1: 
echo "<script>window.location.href=" . Sutil->baseUrlO . "/admin-index.php':</script>": 。”// 重 定向 到 后 台 首 页 
}else{ 
echo "<script>alert( 登 录 失 败 ! ");</script>"; /给 出 登录 失败 提示 
} 
} 
$smarty->display(‘admin-login.phtml"); 
SconnDB->closeConnIDO; /关闭 数据 库 连 接 


也 笈 心 法 


心 法 领悟 613: 防止 后 台 管理 系统 中 的 程序 被 非法 访问 。 

防止 后 台 管 理 系统 中 的 程序 被 非法 访问 ， 关键 就 在 于 登录 成 功 后 创建 的 $_ SESSION['anc] 变 量 ,， 通过 这 个 变 
量 值 来 确保 后 台 管 理 员 的 特殊 权限 。 在 执行 后 台 管 理 系统 中 的 操作 时 ， 帮会 首先 判断 这 个 S_SESSIONTano 变量 
的 值 ， 如 果 为 空 ， 则 说 明 是 非法 访问 ， 那 么 将 给 出 提示 信息 ， 并 跳 转 到 后 台 管 理 系 统 的 登录 页 面 。 


趣味 指数 : 实 容 页 认 | 


实例 说 明 


明日 科技 图 书 网 站 的 后 台 管理 员 登 录 成 功 后 ， 将 进入 到 后 台 管理 系统 的 主页 ， 主 页 通过 frame 框架 设计 ， 
展示 出 后 台 管 理 系统 中 的 所 有 功能 ， 其 页 面 效果 如 图 15.45 所 示 。 


二 用 信息 管理 


Lm 7 


图 15.45 后 台 管理 系统 主页 


图 关键 技术 


在 后 台 管 理 系统 的 主页 中 ， 应 用 frame 框架 将 后 台 管理 系统 主页 分 为 两 部 分 : 左 侧 的 导航 页 面 和 右 侧 的 中 
心 内 容 显示 页 面 。frame 框架 的 代码 如 下 : 


加 载 中 
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图 秘笈 心 法 


心 法 领悟 614: 超 链接 中 target 属性 的 应 用 。 

超 链 接 中 target 属性 包含 5 个 属性 值 ，_blank 在 新 窗口 中 打开 超 链 接 文 件 ，_parent 将 链接 文件 载 入 含有 链 
接 框架 的 父 框架 或 窗口 中 , 如 果 含 有 该 链接 的 框架 不 是 嵌 套 的 , 则 在 浏览 器 全 屏 窗口 中 载 入 链接 的 文件 , 与 _self 
参数 相同 ; _self 在 同一 框架 或 窗口 中 打开 链接 的 文件 ， 此 参数 为 默认 值 ， 通 常 不 必 指 定 ; _top 在 当前 的 整个 浏 
览 器 窗口 中 打开 链接 的 文件 ， 因 此 会 删除 所 有 框架 ，name 在 指定 的 窗口 或 框架 中 打开 网 页 。 

在 本 项 目的 admin-leftphtml 模板 页 中 ， 通 过 超 链接 的 target 属性 指定 mainwindow 框架 ， 在 该 框架 中 打开 
链接 的 网 页 。 


15.9 系统 管理 


系统 管理 主要 用 于 对 系统 公用 信息 进行 设置 及 对 管理 员 密码 进行 更 改 , 通过 该 模块 可 以 提高 系统 的 可 维护 性 。 


高 级 
趣味 指数 : 窒 食 食 而 ， 


实例 615 


图 实例 说 明 


明日 科技 图 书 网 的 系统 信息 设置 主要 用 于 设置 商城 DD、 企 业 账 号 、 企 业 版 权 、 联 系 方式 和 程序 文件 的 保存 
路 径 等 信息 ， 系 统 信息 设置 的 页 面 如 图 15.46 所 示 。 


当前 位 置 : 听 日 网 上 书本 管理 中 心 )》 不 红 太 自 这 坚 
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图 15.46 系统 信息 设置 页 面 


图 关键 技术 


在 本 实例 中 ， 关 键 之 处 不 在 于 系统 信息 设置 功能 的 实现 方法 ， 更 重要 的 是 它 的 操作 。 在 进行 系统 信息 设置 
时 ， 必 须 设置 最 后 3 项 内 容 ， 它 们 指定 的 是 系统 中 图 片 、 广 告 和 试 读 文件 的 下 载 地 址 ， 如 果 设 置 的 路 径 不 正确 ， 
那么 这 3 项 内 容 将 不 能 正确 输出 。 

笔者 在 编写 此 项 目 时 , 将 其 路 径 设 置 为 http://127.0.0.1/MR/15/005/, 这 是 在 本 地 服务 器 运行 的 路 径 ， 如 果 将 
这 个 程序 上 传 到 互联 网 的 服务 器 中 ， 就 必须 修改 这 个 路 径 ， 否 则 将 找 不 到 指定 的 图 片 和 文件 。 
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图 设计 过 程 


系统 信息 设置 功能 由 admin-defaultphp 和 admin-defaultphtml 两 个 文件 组 成 。 
(1) 在 admin-defaultphp 文件 中 ， 完 成 数据 库 中 存储 的 系统 信息 的 输出 和 更 新 两 项 操作 。 首 先 ， 包 含 后 台 
管理 系统 的 头 文件 。 然 后 ， 判 断 form 表单 中 提交 的 merid 值 是 否 为 室 ， 如 果 不 为 室 ， 则 应 用 数据 库 管理 类 的 
executeSQL( 方 法 执行 更 新 语句 ， 更 新 数据 库 中 存储 的 系统 信息 。 最 后 ， 应 用 数据 库 1 管理 类 的 executeSQL() 方 法 
执行 查询 操作 ， 查 询 数据 库 中 存储 的 系统 信息 ， 并 将 其 存储 到 模板 变量 中 ， 其 代码 如 下 : 
<?php 


ire_once ‘admin-header.php'; // 包 含 网 站 头 文件 
让 (isset($_POST[merid]) &é& $_POST['merid] =") { / 济 断 表单 提交 的 数据 是 否 为 空 

if(! $adminDB->executeSQL("update tb_system set merid=" . S$_POST[merid] . ", meracct=" . $, Ores] ™, readurl=" . 
$ POSTh'readurl"] . ", bookimgurl=" . $ POSTh'bookimgurl" . ™, ggurl=" . $ POSTf'ggurl'] . " bq=" . $ POST['bq'] . " , address—" . 
$_POST[address'] . ", tel=" . $_POST['tel] . ", cz=" . $_POST[cz] .", email=". $_POST[email] . ", icp=" . $_POST[icp] . ", qq=" . $_POST['qq] . 

™ where mark=1", SconnID)) ){ 
echo "<script>alert(' 系 统 信息 设置 失败 ! ");</script>"; 
}else { 


echo "<script>alert(' 系 统 信息 设置 成 功 ! ");</script>"; 

} 
} 
S$system = $adminDB->executeSQL("select id merid, meracct, readurl, bookimgurl, ggurl, bq, address, tel, cz, email, icp, qq from tb_system where 
mark=1", $connID); 
Ssmarty->assign('systenY, $system); // 将 查询 结果 赋 给 模板 变量 
Ssmarty->display('admin-default.phtml"); /| 指定 模板 页 
require_once ‘admin-footer.php’; // 包 含 网 站 尾 文件 


(2) 新 建 admin-default.phtml 模板 页 ,创建 form 表单 ， 提 交 需 要 更 新 的 系统 信息 ， 并 且 将 模板 变量 中 传递 
的 系统 信息 作为 表单 元 素 的 默认 值 。 
图 秘笈 心 法 
心 法 领悟 615: 通过 JavaScript 脚本 中 的 chkinputsysteminfo0 方 法 验证 表单 元 素 值 。 
在 本 实例 的 admin-default.phtml 模板 页 中 ， 调 用 js/adminfunjs 文件 中 的 chkinputsysteminfo0 方 法 对 系统 信 
息 设置 表单 中 提交 的 数据 进行 验证 。 


Tm | 
实 高 级 
图 实例 说 明 


为 了 便于 网 站 管理 者 对 网 站 进行 管理 ， 提 高 网 站 的 安全 性 ， 在 系统 管理 模块 增加 管理 员 密 码 修改 功能 ， 如 
图 15.47 所 示 。 


15.47 管理 员 密码 修改 


图 关键 技术 


更 改 管理 员 密码 的 原理 : 用 户 在 上 述 表 单 中 输入 原 密码 和 新 设 定 的 密码 ， 单 击 “ 更 改 ” 按 钮 将 表单 中 的 信 
息 提交 到 admin-changepwd.php 文件 中 对 密码 进行 更 改 ,在 该 文件 中 ， 首 先 判断 用 户 输入 的 原 密码 是 否 正确 ， 如 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 关键 技术 


在 图 书 大 类 管理 中 ， 应 用 最 多 的 就 是 数据 库 管理 类 中 的 executeSQL0O 方 法 ， 通 过 该 法 执行 SQL 语句 ， 完 成 
数据 库 中 数据 的 添加 、 更 新 、 查 询 和 删除 操作 ， 这 也 是 所 有 后 台 管理 系统 中 最 为 常用 的 管理 手段 。 
图 设计 过 程 
(1) 添加 图 书 大 类 信息 由 admin-bigtype.phtml 和 admin-bigtype.php 两 个 文件 组 成 。 在 admin-bigtype.phtml 


模板 页 中 ,创建 form 表单 ， 将 图 书 大 类 的 名 称 提交 到 admin-bigtype.php 文件 中 进行 处 理 ， 并 且 创 建 添加 图 书 大 
类 信息 和 浏览 图 书 大 类 信息 的 按钮 ， 其 关键 代码 如 下 : 

<div style="width:98%; height:25px; text-align:left"> 

<input type="button" value=" 添 加 图 书 大 类 信息 ” onclick="window location href- {util->baseUrl}/admin-bigtype.php" />&nbsp:&nbsp: 

<input type="button" value=" 浏 览 图 书 大 类 信息 " onclick="window .location href- {util->baseUrl}/admin-listbigtype.php"/> 

</div> 

在 admin-bigtype.php 文件 中 , 获取 表单 中 提交 的 图 书 大 类 名 称 , 首先 , 应 用 数据 库 管 理 类 中 的 executeSQLO 
方法 执行 查询 操作 ， 判 断 在 数据 库 中 是 否 存在 该 类 别 ， 如 果 不 存在 ， 则 应 用 数据 库 管 理 类 中 的 executeSQL() 方 
法 执行 添加 操作 ， 完 成 图 书 大 类 的 添加 操作 ， 其 代码 如 下 : 


<php 
require_once ‘admin-header.php'; // 包 含 网 站 头 文件 ， 在 头 文件 中 包含 了 配置 文件 
if (isset($_POST['typename']) && $_POST[typename] !=") { // 判 断 类 别名 称 是 否 为 空 


if(! $adminDB->executeSQL("select id, typename from tb_bigtype Where typename=" . trim($_ POST['typename]) ."", $connID)) { 
if(! $adminDB->executeSQL("insert into tb_bigtype(typename, addtime) values(" . trim($_POST['typename]) . ™, " . date(Y-m-d His) . ")", 
S$connID)) { 
echo "<scriipt>alert( 类 别 添加 失败 ! );</script>"; 
}elsef 
echo "<script>alert( 类 别 添加 成 功 ! ”);</script>"; 


} 
}else{ 
echo "<script>alert(' 该 类 别 已 经 添加 ! :</script>"; 
} 
} 
$smarty->display('admin-bigtype.phtml): /指定 模板 页 
require_once 'admin-footer.php'; /包含 尾 文件 


(2) 浏 览 图 书 大 类 信息 由 admin-listbigtype.php 和 admin-listbigtype.phtml 文件 组 成 。 在 admin-listbigtype.php 
中 ， 定 义 图 书 大 类 信息 的 删除 、 更 新 和 查询 3 个 方法 ， 完 成 对 图 书 大 类 信息 的 操作 ， 其 代码 如 下 : 


<?php 
require_once 'admin-header.php': /包含 头 文件 
if (isset($_GET[f]) &é& $_GET[?] — 'del) { 1/ 判断 是 否 是 执行 的 删除 操作 


if(! $adminDB->executeSQL("delete from tb_bigtype where id=" .S_GET[id] . "", $connID)) { 
echo "<scriptf>alert( 类 别 删 除 失败 ! ");</script>"; 
} 


} 
SisShow = 下; 
if((isset($_GET['f]) && $_GET[?] — 'edit) || (isset($_POST[f)) && $_POST[f] — ‘edit)) { // 判 断 是 否 是 执行 的 更 新 操作 
if(isset($_POST[?]) && $ POST[?f] — "edit) { 1/ 判断 是 否 是 执行 的 更 新 操作 
if (! $adminDB->executeSQL("update tb bigtype set typename=" . $ POSTP'typename] .” whereid=".$ POST[id]1."",SconnID)){ 
echo "<script>alert( 类 别 更 改 失 败 ! 0);</script>"; 
} else { 
echo "<script>alert( 类 别 更 改 成 功 ! ):</script>"; 
3 
} 
证 (isset(S_GET[id]) { /获取 数据 的 了 
$id=$ GET[id1: 
} else { 
$id=$ POST[id1: 
} 
SisShow = T'; 
Sbigtype = $adminDB->executeSQL("select id. typename from tb_bigtype where id=" . $id . "". $connID); /| 执行 数据 的 查询 操作 
S$smarty->assign('bigtype', $bigtype): // 将 要 重新 编辑 的 信息 赋 给 模板 变量 


} 
Ssmarty->assign('isShow'. $isShow): 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(2) 在 图 书 小 类 展示 模块 中 ， 主 要 显示 出 图 书 小 类 


的 名 称 、 所 属 大 类 和 小 类 添加 时 间 , 其 运行 效果 如 图 15.50 [ssn EE 
所 示 。 Ee ee 外 
单 击 图 书 小 类 信息 列表 页 中 的 “编辑 ” 按钮 ， 将 出 现 小 
类 编辑 表单 , 用 户 更 改 小 类 信息 并 提交 表单 后 , 表单 内 容 将 图 15.50 图 书 小 类 信息 列表 
被 提交 到 admin-listsmalltype.php 文件 中 实现 对 图 书 小 类 信息 的 更 改 ， 其 关键 代码 如 下 
SisShow = 了 


Sbtypes = $adminDB- i a SconnID); /获得 大 类 信息 
for ($i= 0; $i < count(Sbtypes): Si ++) { // 将 大 类 信息 保存 到 数组 中 
SarrayBtypeOption[ $btypes[$ilf'id"] = $btypes[SilP'typenamel; 


S$smarty->assign( arrayBtypeOption', SarrayBtypeOption); 
if (isset($_POST['f]) && $ POST[T] 一 'edit){ /进行 编 辑 操作 


if(! mW tb_smalltype set typename=" . $ POST['typename'] . ", bigtypeid=" . $_ POST[bigtypeid] . ” where 


id=" .$ POST[id] . "", $connID)) 
echo RE 别 更 改 失 肌 1 ;</script>"; 
Yelse{ 

echo "<script>alert( 类 别 更 改 成 功 ! :</script>"; 
3; 


} 

if (isset($ GETT'id")) { 
$id=$_ GET[id]: 

else { 


$smalltype = CT bigtypeid from tb_smalltype where id=" . $id . "", $connID); /查询 小 类 信息 


Ssmarty->assign('smalltype'. $smalltype); 


二 述 代码 首先 关 Ws _GET[Yf] 数 组 元 素 是 否 已 经 设置 ， 如 果 是 ， 则 说 明 用 户 单 击 “ 编 辑 ” 按 钮 ， 这 时 查询 出 
所 有 大 类 名 称 ， 并 使 当前 所 编辑 小 类 的 大 类 名 称 处 于 选中 状态 ， 然 后 判断 是 否 设置 $ POST[f] 数 组 元 素 的 值 ， 
如 果 是 ， 则 说 明 已 经 提交 小 类 信息 更 改 表单 ， 此 时 通过 数据 库 管理 类 的 executeSQL0 方 法 更 改 小 类 信息 。 

(3) 如 果 管 理 员 单 击 小 类 信息 列表 页 中 的 “删除 ” 按钮 ， 则 首先 弹出 一 个 提示 框 来 提示 用 户 是 否 确认 删除 ， 


如 果 是 ， 则 通过 数据 库 管 理 类 的 executeSQL0O 方 法 执行 delete 语句 删除 指定 的 小 类 信息 ， 其 代码 如 下 : 
if (isset($_GET['?]) && $_GET[f] — ‘del) { 
if(! $adminDB->executeSQL("delete from tb smalltype where id=" .S GETTid]."", $connID)) { 
echo "<script>alert( 类 别 删除 失败 ! ");</script>"; /执行 删除 
} 


} 
国 秘笈 心 法 


心 法 领悟 618: 应 用 issetO 函 数 判 断 指 定 的 变量 是 否 存在 。 

issetO 函 数 ， 检 查 变量 是 否 被 设置 ， 如 果 设 置 则 返回 TRUE， 和 否则 返回 FALSE。 由 于 这 是 一 
函数 ， 因 此 它 无 法 被 “变量 函数 ”调用 ， 其 语法 如 下 : 

boolisset (mixed var [ mixed var [, .J]) 


参数 var 为 被 检查 的 变量 ， 可 以 有 多 个 。 


力 实例 说 明 
图 书 不 但 可 以 按 内 容 划分 ， 还 可 以 按 其 所 属 出 版 社 进行 分 类 ， 这 样 可 以 更 加 方便 地 引导 读者 选 购 自 


结构 而 非 


己 信赖 
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的 出 版 社 所 出 版 的 图 书 。 为 使 出 版 社 分 类 更 加 形象 、 易 于 识别 , 在 出 版 社 分 类 中 增加 了 出 版 社 的 logo 图 片 信息 ， 
浏览 出 版 社 类 别 信 息 的 页 面 效果 如 图 15.51 所 示 。 


瑟 世 杰克 返 出 台 示 
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图 15.51 浏览 出 版 社 类 别 信息 


图 关键 技术 


在 出 版 社 分 类 管理 中 , 关键 是 出 版 社 logo 图 标 上 传 的 实现 方法 , 其 上 传 应 用 的 是 move_uploaded file0 函 数 。 
(1) 在 执行 上 传 之 前 ， 应 用 is_dir0 函 数 判 断 指定 的 文件 夹 是 否 存在 ， 如 果 不 存在 则 应 用 mkdir0 函 数 创建 
-个 新 文件 夹 。 
(2) 应 用 $_FILES[] 全 局 数组 获取 上 传 图 片 的 原始 名 称 。 
(3) 定义 上 传 文件 在 服务 器 文件 夹 下 的 存储 名 称 ,应 用 date0 获 取 时 间 戳 , 应 用 mt_rand0 函 数 定义 随机 数 ， 
通过 substr0 函 数 获取 原始 文件 的 后 级 名 称 ， 从 而 组 成 新 的 文件 名 称 。 
(4) 定义 上 传 文件 在 服务 器 中 的 存储 路 径 。 
(5) 应 用 move_uploaded_file0 函 数 执行 文件 上 传 操作 。 
上 述 函 数 的 详细 讲解 可 以 参考 本 书 第 4 章 的 内 容 ， 这 里 不 再 资 述 。 
图 设计 过 程 
(1) 网 站 管理 者 在 添加 出 版 社 名 称 并 选择 出 版 社 logo 图 片 后 ， 单 击 “ 添 加 ”按钮 即 可 将 出 版 社 类 别 信息 
提交 到 admin-pub.php 文件 中 进行 处 理 ， 其 代码 如 下 : 
if (isset($_POST['pubname']) && $_POST[pubname] !=") { // 和 如果 提交 了 表单 
if(! $adminDB->executeSQL("select id, pubname from tb_pub where pubname=" . trim($_POST[pubname']) . "", $connID)) { 1 判断 该 出 


版 社 是 否 已 经 添加 
if (isset($_FILES["pubimg"]["name"]) && $_FILES["pubime"]["name"] !="") { 1/ 上传 出 版 社 logo 
les/bookimg"; 


人 $_FILES["pubimg"]["name"]: 
Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr(Supfilename. strpos($upfilename. "."). strlen($upfilename) - 
strpos($upfilename, ".")); /设置 出 版 社保 存 文件 名 
Saddress = $dir . "/" . $filename: 
@move_uploaded file($_FILES["pubimg"]["tmp_name"], Saddress): /| 执行 上 传 操作 
}else { 
Sfilename =""; 


1 
有 insert into 节 pub(pubname. pubimg, addtime) values(" . trim(S_POST[pubname]) . "," . $filename .™." . 
date(Y- Me ")", $connID) /保存 出 版 社 类 别 信息 
i 版 社 类 别 汪 加 失败 1 :script>": 
}elsef 
echo "<script>alert( 出 版 社 类 别 添加 成 功 ! ;</script>"; 
} 
}elsef 
echo "<script>alert( 该 出 版 社 类 别 已 经 添加 ! ;</script>"; 
} 
} 
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上 述 代码 使 用 函数 move_uploaded _ file0 上 传 出 版 社 logo， 成 功 上 传 后 ， 使 用 数据 库 管 理 类 的 executeSQLO 
方法 执行 msert 语句 保存 出 版 社 类 别 信息 。 
(2) 出 版 社 类 别 信息 列表 页 显示 出 版 社 logo、 出 版 社 名 称 和 类 别 添加 时 间 。 管 理 员 单 击 出 版 社 类 别 列表 中 
的 “编辑 ” 超 链接 ， 将 出 现 出 版 社 类 别 更 改 表单 ， 对 出 版 社 信息 进行 编辑 ， 将 表单 内 容 提 交 到 admin-listpub.php 
文件 中 进行 处 理 ， 其 代码 如 下 : 
SisShow = FP’; 
if((isset($_GET['f]) && $_GET[f] — 'edit) I A POST[TD &&S POST[f] — ‘edit)) { 
if (isset($ POST[TD && $ POSTIT]— 
if (isset($_FILES["pubimeg" Rs FILES["pubimg"]["name"] := "") { / 济 断 是 否 重新 上 传 logo 
Sdir= "./upfiles/bookimg"; 
if(!is dir(Sdir) { 


mkdir(Sdir); 
} 
Supfilename = $_FILES["pubimg"]["name"]: 
SS = date("YmdHis") . mt rand(1000. 9999) . substr($upfilename, strpos($upfilename, "."), strlen($upfilename) - 
Poel 


Saddress = Sdir . "/" . $filename; 
@move_uploaded file($_FILES["pubimg"]["tmp_name"], $address); /执行 上 传 
}else{ 
Sptmp = $adminDB->executeSQL("select pubimg from tb_pub where id=" .trim($_ POST['id]) . "", $connID); 
n Sfilename = $ptmp[Olf'pubimg"; 
if(! $adminDB->executeSQL("update tb_pub set pubname=" . $ POST[pubname'] . ", pubimg=" . $filename ." where id=". 
S _POST[id] . "", $connID)) { /更 改 出 版 社 类 别 信息 
echo "<script>alert( 出 版 社 类 别 更 改 失败 ! ));</script>"; 
} else { 
echo "<script>alert( 出 版 社 类 别 更 改 成 功 ! ");</script>"; 
中 


Yr Gssetts GErpiaD) { 
$id=$_ GET[id]; 
a =S_POST[id]:; 
CA 要 
S$pub = $adminDB->executeSQL("select id, pubname, pubimg from tb_pub where id=" . $id . "", $connID); 
$smarty->assign(pub', Spub): 
上 述 代 码 首先 判断 是 否 又 重新 上 传 出 版 社 logo， 如 果 是 ， 则 重新 上 传 ， 反 之 则 不 进行 任何 操作 ， 然 后 使 用 
数据 库 管 理 类 的 executeSQL0O 方 法 执行 update 语句 更 改 出 版 社 类 别 信息 。 


(3) 如 果 单 击 出 版 社 类 别 列表 “删除 ”按钮 ， 并 确认 删除 后 , 将 通过 如 下 代码 删除 指定 的 出 版 社 类 别 信息 : 
if (isset($_GET[?)) && $_GET[?] —'del) { 
if (! $adminDB->executeSQL("delete from tb_pub where id=" .S_GET[id] . "", $connID)) { 
echo "<script>alert( 出 版 社 类 别 删除 失败 ! :</script>"; 
} 
} 


力 秘笈 心 法 


心 法 领悟 619: 删除 存储 在 数据 表 中 的 出 版 社 类 别 信息 
这 样 删 除 的 只 是 存储 在 数据 表 中 的 出 版 社 类 别 信息 ， 并 不 将 存储 在 服务 器 文件 夹 下 的 图 片 删 除 。 如 果 要 
删除 存储 在 服务 器 文件 夹 下 的 图 片 ， 必 须 在 服务 器 文件 夹 下 手动 删除 。 


15.11 图 书 


恒 书 管理 模块 主要 用 于 对 图 书信 息 和 图 书 试 读 信息 进行 管理 ， 本 节 将 以 实例 的 形式 对 明日 科技 图 书 网 的 图 
书信 息 管 理 模块 进行 讲解 。 


实例 620 


图 实例 说 明 


明日 科技 图 书 网 的 定位 为 图 书 产 品 的 展示 和 销售 ， 所 以 图 书信 息 管理 模块 非常 关键 ， 该 项 目的 图 书信 息 管 


理 模 块 主要 包括 对 图 书信 息 


的 名 称 、 类 别 、 页 数 、 字 数 、 作 者 、ISBN 号 和 价格 等 ， 其 运行 效果 如 图 15.52 所 示 。 


力 关键 技术 
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图 15.52 ”图书 信息 添加 


的 添加 、 更 改 、 删 除 和 查询 等 操作 。 在 图 书信 息 添加 页 面 中 ， 添 加 的 内 容 包 括 图 书 


在 图 书信 息 管理 中 ， 非 常 关键 的 一 点 是 明确 数据 表 的 各 个 字段 代表 的 含义 ， 在 明日 科技 图 书 网 的 前 台中 ， 
在 对 图 书信 息 进 行 分 类 时 ， 根 据 的 就 是 图 书信 息 表 中 某 个 字段 的 值 ， 例 如 ， 判 断 图 书 是 否 是 新 书 、 是 否 特价 等 。 
所 以 必须 对 图 书信 息 表 中 各 个 字段 了 如 指 掌 才 能 更 好 地 完成 判断 操作 。tb_bookinfo 图 书信 息 表 的 说 明 如 表 15.2 


所 示 。 
表 15.2 tb_bookinfo 图 书信 息 表 

字段 名 称 数据 类 型 说 了 明 
id int 自动 增长 
bookname varchar 大 类 名 称 
smalltypeid datetime 添加 时 间 
oldprice float 图 书 原价 
newprice float 本 站 价格 
bookimg varchar 图 书 封面 图 片 名 称 
isnew, bool 是 否 新 书 
addtime datetime 添加 时 间 
abonut text 图 书 介绍 
issepprice bool 是 否 特价 图 书 
browsertime int 浏览 次 数 


887 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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1f(! is_dir($din) { 
mkdir($dir); 


} 

Supfilename = $_FILES["bookimg"]["name"]: 

Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr(Supfilename. strpos($upfilename. "."), strlen($upfilename) - 
strpos($upfilename, ".")); 


Saddress = $dir . "/". $filename; 

@move uploaded file($ FILES["bookimg"]["tmp name"l, Saddress): 
}else{ 

Stmpbook = $adminDB->executeSQL("select bookimg fiom tb_bookinfo where id=" . $_POST['id] . "", SconnID); 
Sfilename = $tmpbook[OlPbookimg |; 


=$_POST[pyear] . ~. $_POST['pmonth'] . '-00 
-由 用 户 设 轩 提 内 大 的 代 员 ， 请 窗 朵 脐带 光盘 中 洒 玛 


trim(s$_POST['smalltypeid]) . ”Pubid-”. trim($_POST['pubid") . ", page=" .trim(S_ POST[pageJ) . ” zs -im(S_POST[zs]) . ", isbn=" . 
trim($_POSTTisbn]) . ", be=" . trim($_POST['be"]) . ", writer=" . trim($_ POST[writer]) . ™, pubtime=" . Spubtime . ™, oldprice=" . 
trim($ POST'oldpriceT) .". ee trim($ POST[mewpriceT) . ", bookcc=" . trim($ POST['bookce") . ™, bookids=" , trim($ ed 
", bookimg=" . $filename . ", directory=" .trim(S POSTTdirectory]) . ", about-” , trim($_POST['about]) . ", isnew=". Sisnew . ", i 
Sissepprice . ", ishotsell=" . $ishotsell . ", isterm=" . $isterm . "ismrbooktj=" . Sismrbooktj . " ,ishave=" . Sishave . ™ where id=" ‘Ss ee ep 
SconnID)) { /更 改 图 书信 息 
echo "<script>alert( 图 书信 息 更 改 失 败 ! ;</script>"; 
yelse{ 
echo "<script>alert(' 图 书信 息 更 改 成 功 ! "</script>"; 
3 


六 
if (isset($_POST['d'])) { 
$id=$_POST[id]; 
jelse 
$id = $_GET['d']; 


i eh id, bookname, smalltypeid. pubid, page, zs, isbn, bc, writer, pubtime, oldprice, newprice, bookcc, bookids, 
bookimg, directory, about, isnew, issepprice, ishotsell, isterm ,ismrbooktj ,ishave, addtime, browsertime from tb_bookinfo where id=" . $id . "”"， 
SconnID); /二 和 书信 

$smarty->assign("book’, $book); 

$smarty->assign(pyear, substr($book[0][pubtime], 0, 4)); 

S$smarty->assign(pmonth', substr($book[O]['pubtime’], 5, 2)): 
在 上 述 代码 中 ， 定 义 图 书信 息 添加 和 更 新 两 种 操作 。 首 先 判断 $ _POST[change] 数 组 元 素 的 值 ， 如 果 该 值 为 
EF， 则 进行 添加 操作 ， 通 过 数据 库 管理 类 的 executeSQL0 方 法 执行 insert 语句 将 图 书信 息 保 在 到 数据 库 中 ， 同 时 
使 用 函数 move_uploaded_file0 将 图 书 封面 上 传 到 服务 器 中 ;如 果 $_POST['change'] 的 值 为 T， 则 执行 图 书信 息 的 
更 改 操作 , 在 更 改 图 书信 息 时 , 首先 判断 是 否 重 新 选择 图 书 封面 , 如 果 是 , 则 重新 上 传 图 书 封面 , 然后 执行 update 
语句 对 图 书信 息 进行 更 新 。 
(2) 图 书信 息 列表 主要 对 图 书 名 称 、 出 版 社 、 作 者 和 价格 等 进行 分 页 显示 ， 其 运行 效果 如 图 15.53 所 示 。 


ET 
出版 社 作用 市 双 攻 (元 )》 会 员 价 ( 元 》 缺 作 - 

A 晰 社 。 | 他 天 忆 汉人 对 网 EY 1%.00 区 首 习 

1 

T [EEZEL ET | EE EF 

A 让 ER EE EE 区 

A 8 一 | 等 吕 

[AR | Wee TA EC FP 


15.53 ”图 书信 息 列 表 


通过 图 书信 息 列表 页 可 以 实现 对 图 书信 息 的 更 改 和 删除 操作 ， 在 讲解 图 书 添加 操作 中 已 经 介绍 了 图 书信 息 
更 改 的 实现 方法 ， 这 里 不 再 次 述 。 当 单 击 图 书信 息 列表 中 的 “删除 ”按钮 时 ， 首 先 弹 出 提示 对 话 框 提 示 用 户 是 
和 否 确 认 删 除 ， 如 果 是 ， 则 通过 如 下 代码 执行 对 图 书信 息 的 删除 操作 : 
if (isset($_GET[f]) && $_ GET[?] — "del) { 
if(! $adminDB->executeSQL("delete from tb bookinfo where id=" .S GETTid] .™", $connID)) { 
echo "<script>alert( 图 书信 息 删除 失败 ! :</script>": /执行 删除 操作 
} 
请 
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(3) 与 其 他 管理 模块 相 比 ， 图 书信 息 量 较 大 ， 为 方便 对 图 书信 息 进行 管理 ， 在 图 书信 息 管理 模块 中 增加 了 
图 书信 息 查询 功能 ， 其 运行 效果 如 图 15.54 所 示 。 


医 工 LE 


er: FE ED 


下 而 到 的 图 书后 息 


[3 出 版 社 作者 市 般 价 {元 会 员 作 5 元 3 
0 开具 到 村 ET EEEI mm | wm [者 钙 


15.54 ”图 书信 息 查 询 


首先 在 文本 框 中 输入 要 查询 的 关键 字 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 这 时 查询 表单 的 关键 字 将 被 提交 到 
admin-searchbook.php 文件 中 ， 在 该 文件 完成 对 图 书信 息 的 查询 操作 ， 并 且 将 查询 结果 赋 给 模板 变量 ， 在 模板 页 


admin-searchbook.phtml 中 输出 查询 结果 ， 其 代码 如 下 : 
SisFind = FP'; 


if (isset($_POST[‘bookname']) && $ POST[bookname'] !=" || isset($_GET['bookname"]) && $ GET['bookname'] !=") { // 判 断 是 否 提交 了 表单 
if(isset($_POST['bookname])) { /获取 要 查询 的 图 书 名 称 
$bookname =$ POSTI'bookname'l; 
} else { 


S$bookname =$_GET['bookname’]; 
} 
S$books = $adminDB->executeSQL("select tb_bookinfo.id , tb_bookinfo.oldprice, tb_bookinfo.newprice, tb_bookinfo.bookname, 


tb_bookinfo.writer, tb_pub.pubname from tb_bookinfo. tb_pub where tb_bookinfo.pubid = tb_pub.id and bookname like '%%" . $bookname . "%%" 
by tb_bookinfo.addtime desc", $connID): / 妆 和 横 央 宫 向 
Ssmarty->assign(‘books', $books); 
SisFind = "T"; 


} 
上 述 代码 首先 使 用 函数 isset0 判 断 $_POST['bookname'] 数 组 元 素 是 否 已 经 被 设置 ， 如 果 是 ， 则 使 用 数据 库 管 
理 类 的 executeSQL0 方 法 执行 查询 操作 。 


图 秘笈 心 法 


心 法 领悟 620: 通过 like 关键 字 执 行 模糊 查询 ， 查 询 图 书 的 名 称 。 
在 本 实例 的 图 书 查询 中 ， 应 用 like 关键 字 执 行 多 表 模 糊 查 询 ， 查 询 图 书 的 名 称 ， 并 且 将 查询 结果 返回 到 模 
板 变量 中 。 


高 级 | 
站 妆 : 克 认 | 
力 实例 说 明 
为 了 让 读者 选择 一 本 真正 适合 自己 的 图 书 ， 和 吸引 更 多 te 
读者 购买 ， 在 制作 明日 科技 图 书 网 时 增加 了 图 书 试 读 模块 ， 人 
这 样 读者 在 购买 图 书 前 就 可 以 大 概 了 解 所 购买 图 书 的 内 容 ， 有 
非常 人 性 化 。 在 图 书 试 读 信息 添加 页 面 中 包括 图 书 类 别 下 拉 2 sal 
列表 框 、 图 书 名 称 选择 下 拉 列 表 框 和 试 读 文件 名 称 输入 文本 
框 ， 其 运行 效果 如 图 15.55 所 示 。 图 15.55 添加 图 书 试 读 信息 页 面 
图 关键 技术 


在 添加 图 书 试 读 信息 的 模板 页 admin-read.phtml 中 ,通过 Smarty 模板 中 的 {1delim} {rdelim} 标 签 直接 在 模板 


页 中 编写 JavaScript 脚本 ， 应 用 jQuery 技术 实现 下 拉 菜 单 的 三 级 联动 ， 其 关键 代码 如 下 : 
<script sre—" {util->baseUrl}/jsiqueryjs"></script> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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CE Er ET 扶 作 
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等 页 量 示 20 本 第 1 页 / 共 1 页 首页 上 一 页 下 一 页 尾 页 
图 15.56 ”图书 试 读 信息 列表 


单 击 试 读 信 息 列表 的 “编辑 ”图 标 将 出 现 试 读 信息 更 改 表 单 ， 在 该 表单 中 修改 试 读 图 书 的 内 容 ， 将 表单 数 
据 提 交 到 admin-listread.php 页 面 中 进行 修改 ， 其 代码 如 下 : 
if ((isset($_GET['f]) && $ GETI?] — 'edit) | (isset($_POST[f]) && $ POST[?] — ‘edit)) { // 判 断 是 否 提交 了 表单 
让 (isset($_ POST[T]) && $ POST[T] 一 'edit) { 
证 (! $adminDB->executeSQL("update tb read set bookinfoid=" .S_POST[bookid] . "filename=".$_POST[filename]."” where id=" . 
$ POST[id] . "", $connID)) { ” /| 执行 更 改 操作 
echo "<scripf>alert(' 试 读 更 改 失败 ! ;</script>"; 
}else { 
echo "<script>alert(' 试 读 更 改 成 功 ! :</script>"; 
》 
} 
if (isset($_GET[id])) { 
$id=$_GET[id]:; 
jelse 二 
$id=S$ POST[id]; 
SisShow = 了 T: 
Sread = $adminDB->executeSQL("select tb readid. tb_read filename, tb_bookinfo bookname. tb_read.addtime from tb_read, tb_bookinfo where 
tb_read.bookinfoid = tb_bookinfo.id and tb_read id=" . $id . "", SconnID); /查询 试 读 信息 
Ssmarty->assign('read', Sread); 
单 击 试 读 信息 的 “删除 ”图 标 ， 会 弹出 是 否 确认 删除 的 对 话 框 ， 如 果 选 择 确 认 删 除 ， 则 执行 如 下 代码 实现 
试 读 信息 的 删除 : 
if(isset($_GET[f]) && $ GET[?f] — 'del’) { 


if (! $adminDB->executeSQL("delete from tb_read where id=" . $_GET['id"] . "", $connID)) { 
echo "<script>alert(' 试 读 删除 失败 ! ");</script>": /执行 删除 试 读 操作 
} 


} 
图 秘笈 心 法 


心 法 领悟 621: 分 页 功能 的 实现 。 
在 本 实例 中 ， 试 读 信息 的 分 页 输出 应 用 的 是 分 页 类 中 的 pageData0 方 法 ， 将 分 页 查询 结果 赋 给 模板 变量 ， 
在 模板 页 中 创建 分 页 超 链接 ， 完 成 试 读 信息 的 分 页 输出 。 


15.12 用 户 管 理 


户 管理 模块 实现 的 功能 包括 对 网 站 注册 用 户 的 管理 和 对 用 户 反馈 信息 的 管理 ， 本 节 将 讲解 这 两 个 功能 的 
实现 过 程 。 


实例 622 


趣味 指数 : 规 售 评价 | 


图 实例 说 明 
在 用 户 管理 模块 中 对 网 站 注册 用 户 进行 分 页 输出 ， 输 出 内 容 包括 用 户 昵 称 、 真 实 姓 名 、 性 别 和 联系 电话 等 ， 
其 运行 效果 如 图 15.57 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 实例 说 明 


用 户 反馈 管理 模块 输出 用 户 对 网 站 本 身 、 网 站 中 的 某 本 图 书 ， 或 者 其 他 方面 的 一 些 建议 、 意 见 等 ， 其 输出 
效果 如 图 15.58 所 示 。 
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EE 
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共 3 条 二 而 示 20 条 第 1 页 / 共 1 页 。 首页 上 一 页 下 -页 尾 页 
这 看 用 户 反馈 相信 入 
用 广电 种，mc 长 表 对 间 ，2010-06 -13 07:52x42 
发 表 上 时间， 我 的 建议 
和 建议 


图 15.58 浏览 用 户 反 馈 信息 


本 实例 实现 的 功能 与 实例 622 是 相同 的 ， 唯 一 的 不 同 之 处 是 本 实例 操作 的 是 tb_feedback 数据 表 ， 而 用 户 管 
理 实例 操作 的 是 tb_user 表 。 
图 设计 过 程 

(1) 浏览 用 户 反 馈 信息 由 admin-listuserfeedback.php 和 admin-listuserfeedback.phtml 两 个 文件 组 成 。 在 
admin-listuserfeedback.php 文件 中 ， 首 先 ， 判 断 指 定 的 分 页 变量 是 否 存在 。 然 后 ， 根 据 $_GET[] 获 取 的 变量 值 进 
行 判 断 ， 执 行 用 户 反馈 信息 的 删除 操作 、 数 据 的 分 页 输出 或 者 查看 指定 用 户 反 馈 的 详细 信息 。 最 后 指定 模板 页 ， 


其 代码 如 下 : 

<?php 

require_once ‘admin-header.php'; /包含 头 文件 

让 (tisset($_GET[page]) || $_GET[page] —") { 1/ 判断 分 页 变量 是 否 存在 
Spage ="1'; 

}else { 

i Spage =$ GET['page'l: 

if (isset($_GET[f]) && $_GET[?] — 'del) { // 判 断 是 否 执行 删除 操作 
if (! $adminDB->executeSQL("delete from tb_feedback where id=" .S_GET[id] . "", $connID)) { 

echo "<script>alert( 用 户 反馈 信息 删除 失败 ! ;</script>"; 

3 

} 

$sql = "select id usernc. title. addtime from tb feedback order by addtime desc": 

Sfeedbacks = $pageDB->pageData($sql, SconnID, 20. Spagej; /执行 分 页 查询 

Ssmarty->assign('feedbacks'. $feedbacks); 

SisShow = 下: 

if (isset($_GET[f]) && $_GET[?] — 'edit) { 1/ 判断 是 否 执 行 详细 信息 查询 操作 
Suserfeed = $adminDB->executeSQL("select id. usernc. title. content. addtime from tb_feedback where id=" . $_GET['id] ."", $connID); 
SisShow = T'; 
S$smarty->assign(userfeed' $userfeed): // 将 查询 结果 赋 给 模板 变量 

1 

Ssmarty->assign('isShow', $isShow); 

S$smarty->display(admin-listuserfeedback .phtml)): /| 指定 模板 页 

Tequire_once ‘admin-footer.php’: // 包 含 尾 文件 


(2) 新 建 admin-listuserfeedback.phtml 模板 页 。 首 先 ， 通 过 section 语句 循环 输出 用 户 反 馈 信息 ， 并 且 创 建 
查看 指定 用 户 反馈 详细 信息 和 删除 指定 用 户 的 超 链 接 。 然 后 ， 定 义 分 页 超 链 接 ， 完 成 数据 的 分 页 输出 。 最 后 ， 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 1200 例 (第 I 卷 ) 


续 表 
字段 名 称 数据 类 型 说 阴 
numstr varchar 订购 图 书 数量 组 成 字符 串 
goodsprice float 图 书 价格 
yiprice float 邮寄 价格 
totalprice float 总 价格 
Tectype Varchar 收 货 方式 
paytype varchar 支付 方式 
addtime datetime 订购 时 间 
is 全 bool 是 否 付款 
is 也 bool 是 否 发 货 
issh bool 是 否 收 货 
isqx bool 是 否 被 用 户 取消 订购 


图 设计 过 程 


等 操 


页 类 的 pageData0 方 法 实现 订单 信 
句 实 


息 ， 


用 户 订单 管理 首先 完成 用 户 订单 信息 的 分 页 输出 ， 然 后 执行 订单 支付 状态 的 更 改 、 订 单 信息 的 查看 和 删除 
作 。 

(1) 在 admin-listorder.php 文件 中 ， 首 先 ， 包 含 头 文件 ， 根 据 传递 的 查询 字符 串 page 的 值 并 通过 数据 库 分 
息 的 分 页 输出 。 然 后 ， 通 过 数据 库 管理 类 的 executeSQL( 方 法 执行 update 语 


现 订 单 状态 的 更 改 。 最 后 ， 通 过 数据 库 管 理 类 的 executeSQL0 方 法 执行 select 语句 ， 查 询 指定 订单 的 详细 信 
并 且 将 查询 结果 在 模板 页 中 输出 。admin-listorderphp 文件 的 代码 如 下 : 
<2pD 
ed ‘admin-header.php’; // 包 含 头 文件 
if (! isset($_GET[page']) || $_GET['page] —") { 1/ 判断 分 页 变量 的 值 
Spage ="1' 
}else{ 


Spage =$_GET['page']; 


} 
if (isset($_GET[?]) && $ GET[?] — 'del) { 
if (! $adminDB->executeSQL("delete from tb_order where id=" . $_GET['id] 
echo "<script>alert(' 订 单 信息 删除 失败 ! ;</script>"; 


} 
} 
if (isset($_GET['c']) && $_GET[c] =") { // 更 改 订单 状态 
$c=$ GETTe1; 
if($c— 'istk) { /判断 是 否 已 经 付款 
$adminDB->executeSQL("update tb order set isfk = !isfk where id=" . $ GETT'id] . "", $connID): 
} elseif ($c =— 'isfh") { 1/ 判断 是 否 已 经 发 货 
$adminDB->executeSQL("update tb order set isfh = !isfh where id=" . $ GETT'id] . "", $connID); 
} elseif ($c 一 'issh) { /1/ 判 断 是 否 已 经 收 货 
$adminDB->executeSQL("update tb order set issh = 'issh where id=" . $ GETT'id] . "". $connID); 
} 
} 


$sql = "select id, ordemo. usemame. tel, goodsprice, yjprice, totalprice. isfk. isfh, issh, isqx from tb_order order by addtime desc": 
// 定 义 SQL 语句 


$orders = $pageDB->pageData($sql. $connID. 20. $page); /| 执行 分 页 查询 

$smarty->assign('orders'. $orders); // 将 查询 结果 赋 给 模板 变量 

SisShow = F'; 

if(isset($_GET[?]) && $ GET[?] — 'edit) { /判断 是 否 执 行 查看 订单 详细 信息 的 操作 


Sorder = $adminDB->executeSQL("select id ordemo. usemame. address. sex. yb. teL idstr, numstr, rectype. paytype, goodsprice, yjprice, totalprice, 
addtime, is 全 isfh. issh from tb_order where id=" . $_GET['id] . "", SconnID): 。 // 执 行 查询 

Sarraylds = explode('@). Sorderfoj[idstr]): 

SarrayNums = explode('@'. Sorder[ol[numstr]): 

SarrayCarInfos = array(): 

StotalPrice = 0; 

for (Si= 0: $i < count(SarrayIds); $i++) { 


第 15 章 “综合 应 用 


Sbookid = $arrayIds[Sil: 
让 (Sbookid =") { 
StmpArmray = array0: 
Sbookinfo = $adminDB->executeSQL("select id, bookname .oldprice, newprice from tb_bookinfo where id=" . $bookid . "", $connID); 
StmpArrayf'id] = Sbookinfo[0][id]: 
ybooknamer 


array ee ): 
. 

} 

S$smarty->assign('arrayCarInfos', $arrayCarInfos): // 将 生成 的 订单 详细 信息 赋 给 模板 变量 

Ssmarty->assign(order, Sorder); 

SisShow = "T'; 
} 
$smarty->assign('isShow', $isShow); /通过 该 变量 值 判断 是 否 输出 订单 详细 信息 
$smarty->display('admin-listorder.phtml'); /指定 模板 页 
Tequire_once ‘admin-footer.php’; /包含 尾 文件 


(2) 在 admin-listorder.phtml 模板 页 中 ， 首 先 ， 通 过 section 语句 循环 输出 订单 信息 ， 创 建 复 选 框 更 改 用 户 
订单 的 状态 ， 创 建 查看 订单 详细 信息 和 删除 指定 订单 的 超 链接 。 然 后 ， 创 建 数据 分 页 超 链 接 ， 完 成 订单 信息 的 
分 页 输出 。 最 后 ， 输 出 模板 变量 中 存储 的 指定 订单 的 详细 信息 。 其 关键 代码 如 下 : 

<div style="border-right: 1px solid #006D84: {if $orders.data[oID].isqx—1}padding-top:4px {/if}"> 

{if$orders.data[oID].isqx 一 1}- 已 取消 --{else} 付 款 : <input type="checkbox" name="isfk" {if $orders.data[oID].is 人 k 一 1}checked{/if} 
onclick="window.location. href="admin-listorder php?c=isfk&id={Sorders data[oID] idj" />é&nbsp:&nbsp; 

发 货 : <input type="checkbox" name="isfh" {if Sorders.data[oID].isth 一 1}checked{/if} 
onclick="window ,location href- admin-listorder php?c=isfh&cid= {Sorders.data[oID]id}j">&nbsp:&nbsp: 

收 货 ，<input type="checkbox" name="issh" {if Sorders.data[oID].issh 一 1}checked{/if} 

onclick="window.location. href='admin-listorder. php?c=issh&id= {$orders.data[oID].id}"> 

{请 

</div> 

<div style="width:996: height20px: float:left: padding-top:2px"> 

<a href=" {util->baseUrl}/admin-listorder.php?f=edit&id={$orders.data[oID] id}"><img src="futil->baseUrlj/img/edit.gif' border="0"/></a>&nbsp; 
<a href="javascript:if(window.confirm( 确 定 删除 ?")==true) {ldelim}window.location.href='{util->baseUrl}/admin-listorder.php?f=del&id= 
{Sorders.data[oID].id}': {rdelim} "><img sre=" {util->baseUrl}/img/del.gif* border="0"/></a> 

</div> 


力 秘笈 心 法 


心 法 领悟 624: 通过 复 选 框 完成 订单 状态 的 更 改 。 

在 admin-listorder.phtml 模板 页 中 ， 创 建 复 选 框 ， 通 过 onclick 事件 调用 JavaScript 脚本 ， 在 JavaScript 脚本 
中 ,应 用 window 对 象 的 location 方法 调用 admin-listorder.php 文件 ,并 传递 两 个 参数 c 和 id, 在 admin-listorder.php 
文件 中 完成 订单 状态 的 更 改 操作 。 


15.14 通用 信息 管理 


在 通用 信息 管理 模块 可 实现 对 新 闻 公 告 、 网 上 畅销 书 讯 和 明日 图 书 排行 管理 ， 本 节 将 讲解 其 功能 的 具体 实 
现 方法 。 


实例 625 


图 实例 说 明 
在 新 闻 公告 管理 模块 中 ， 可 实现 新 闻 公告 的 添加 、 浏 览 、 更 新 和 删除 操作 。 其 中 在 添加 新 闻 公 告 功 能 中 ， 
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通过 Fckeditor 文本 编辑 器 编辑 公告 的 内 容 ， 其 运行 效果 如 图 15.60 所 示 


昌吉 交加 寺 加 6 同 式 国 导 国名 


| 上 fe BE BE 下 到- 和" 恒 
希 杰 下 过 大 军 的 交流 ， 医 此 天 荐 有 用 内 贡 ,增长 和 在 妆 难 ,开关 目 己 的 各 看 | 
ul Ee 


图 15.60 添加 新 闻 公 告 信息 


图 关键 技术 


在 本 实例 中 ， 关 键 是 如 何在 Smarty 模板 页 中 嵌入 Fckeditor 文本 编辑 器 ， 其 应 用 的 是 Util 类 中 的 editor0 方 
法 。editor0 方 法 的 语法 如 下 : 
finction editor ($name, $value, Swidth ="100%%,, Sheight ='200){ 
require_once 'library/fckeditor/fckeditor.php'; 
SarrayIni = $this->arayIni; 
$oFCKeditor = new FCKeditor($name); 
S$oFCKeditor->BasePath = $arrayInifbaseUrl] . /library/fckeditor/; 
S$oFCKeditor->Width = $width; 
SoFCKeditor->Height = Sheight: 
$oFCKeditor->ToolbarSet = ' Default' 
SoFCKeditor->Value = $value; 
SoFCKeditor->Create0: 


} 
在 lzh.inc.php 文件 中 ， 应 用 Smarty 模板 中 的 register_object0 方 法 注册 一 个 模板 对 象 ， 其 关键 代码 如 下 : 
Sutil = new UtilO; 
es Sutil, null, false); 


代码 如 下 : 
{if $isEdit—"F"} 
{util->editor pl ='content’ p2 ="}<br /><br /> 
{else} 
{util->editor pl ='content' p2 =$info[0].content}j<br /><br /> 
<input type="hidden" name="id" value="{$info[0].idj" 户 
{i 


力 设计 过 程 
(1) 新 闻 公告 的 添加 由 admin-telLphp 和 admin-telLphtml 两 个 文件 组 成 。 在 admin-tell.phtml 模板 页 中 创建 


form 表单 ， 载 入 Fckeditor 文本 编辑 器 ， 将 新 闻 公 告 提交 到 admin-tell.php 文件 ， 完 成 新 闻 公告 的 添加 操作 。 在 
admin-tell.php 文件 中 ， 调 用 数据 库 管 理 类 中 的 executeSQL( 方 法 完成 新 闻 公 告 的 添加 、 更 新 和 查询 操作 ， 其 关 


键 代码 如 下 : 
<?php 
require_once ‘admin-header.php'; // 包 含 头 文件 
iflisset($_POST['title']) && $_ POST['itle]'="&&lisset(S_POST[id]))f // 浏 断 提交 的 ID 和 标题 是 否 为 空 


if(!$adminDB->executeSQL("select id, title from tb_tell where title=".trim($_POSTT'title])."", SconnID)){ 
if(!$adminDB->executeSQL("insert into tb_tell(title, content addtime) values("".trim($_POSTT'title]).", 
mtrim($ POSTPcontent]).",".date("Y-m-d H:i:s).")", $connID){ 
echo "<scriipt>alert(' 公 告 添加 失败 ! ;</script>"; 
jelsef 
echo "<scriptf>alert(' 公 告 添加 成 功 ! ):</scripP>": 
} 
Jelse { 
echo "<scripf>alert(' 该 公告 已 经 添加 ! ));</script>"; 
} 
} 
SisEdit = 下: 
iflisset($_GET['f]) && $_GET[T] 一 edit || isset($_ POST[id]) && $ POST[id]!="){ /1/ 判 断 是 否 执 行 更 新 操作 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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字母 A 关键 字 索 引 
关 键 字 描 述 索 引 页 码 
absolutepage 关键 字 操作 Access 数据 库 分 页 时 ， 设 置 当前 显示 的 为 第 几 页 11.2 节 , 实例 509| 678 页 
absolutepage0 函 数 返回 当前 页 的 页 数 13.1 节 , 实例 540| 736 页 
abstract 关键 字 定义 抽象 类 的 关键 字 7.4 节 ， 实 例 329 | 438 页 
add( 方 法 调用 graph 类 的 将 柱 形 图 数据 添加 到 图 像 中 的 方法 6.3 节 ， 实 例 290 | 384 页 
addslashes0 〇 函数 对 指定 的 SQL 语句 自动 转 义 2.8 节 ， 实 例 084 | 128 页 
adodb pager0) 函 数 类 的 构造 函数 13.2 节 , 实例 542| 739 页 
11.2 节 , 实例 512| 682 页 
12.1 节 , 实例 521| 701 页 
adonewconnection() 函 数 | 连接 数据 库 系统 12.3 节 , 实例 531| 716 页 
13.1 节 , 实例 538| 732 页 
13.2 节 , 实例 544| 742 页 
all 关键 字 利用 该 关键 字 将 多 个 select 语句 的 查询 结果 合并 输出 但 不 删除 重复 行 |8.7 节 ， 实 例 411 | 541 页 
alter table 修改 表 结构 8.3 节 ， 实 例 355 | 478 页 
alter view 修改 视图 9.2 节 ， 实 例 460 | 605 页 
and 关键 字 两 个 或 多 个 表达 式 进行 逻辑 与 运算 , 如 果 有 一 个 为 假 则 运算 结果 为 假 |8.6 节 ， 实 例 383 | 511 页 
any 关键 字 定量 比较 谓词 8.7 节 ， 实 例 414 | 544 页 
2.4 节 ， 实 例 058 | 100 页 
2.5 节 ， 实 例 064 | 107 页 
2.5 节 ， 实 例 072 | 116 页 
2.6 节 ， 实 例 077 | 121 页 
2.7 节 ， 实 例 080 | 124 页 
2.7 节 ， 实 例 082 | 126 页 
onay0 数 返 加 根据 参数 建立 的 数组 eed de 
2.10 节 , 实例 125| 163 页 
2.10 节 . 实例 126| 164 页 
2.10 节 , 实例 128| 165 页 
2.10 节 , 实例 129| 165 页 
2.10 节 , 实例 130| 166 页 
2.10 节 , 实例 140| 174 页 
array chunk(O) 函 数 数组 的 拆 分 2.10 节 , 实例 139| 173 页 
array filterO 函 数 用 回调 函数 过 滤 数 组 中 的 单元 4.1 节 ， 实 例 227 | 293 页 
array_key_exists0 函 数 “| 检查 数组 中 是 否 存在 某 个 值 2.10 节 , 实例 135| 170 页 
array_mergeO 函 数 合并 数组 2.10 节 , 实例 138| 172 页 


加 载 中 
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续 表 
关 键 字 描 述 索引 页 码 
chr0 函 数 将 ASCII 码 转换 为 字符 2.8 节 ， 实 例 105 | 145 页 
class 关键 字 类 的 定义 7.1 节 ， 实 例 322 | 429 页 
clear all cache( 方 法 “| 清除 所 有 模板 的 缓存 14.1 节 , 实例 580| 798 页 
clear_cache0 方 法 清除 指定 模板 的 缓存 14.1 节 , 实例 580| 798 页 
clone 关键 字 实现 对 对 象 的 克隆 7.6 节 ， 实 例 335 | 447 页 
4.6 节 ， 实 例 252 | 326 页 
closedir0 函 数 关闭 目录 句柄 46 节 ， 实 例 253 | 327 页 
commit0 方 法 利用 该 方法 可 以 实现 提交 所 有 查询 用 et ee - 
committrans() 函 数 成 功 完成 数据 库 操作 时 执行 13.2 节 , 实例 549| 748 页 
compile_dir 编译 目录 存储 位 置 14.1 节 , 实例 558| 760 页 
config dir 配置 文件 存储 位 置 14.1 节 , 实例 558| 760 页 
config load0 函 数 内 建 函数 14.1 节 , 实例 581| 799 页 
12.1 节 , 实例 521| 701 
omnes i 13.1 区 538| 732 有 
const 关键 字 常量 声明 7.1 节 ， 实 例 322 | 429 页 
6 跳 过 本 次 循环 中 剩余 的 代码 并 在 条 件 求 值 为 真 时 开始 执行 下 一 次 |2.6 网 实例 075 | 119 页 
循环 2.6 节 ， 实 例 076 | 120 页 
conVertO 函 数 数据 类 型 转换 10.4 节 , 实例 501| 666 页 
copyO 函 数 复制 文件 4.4 节 ， 实 例 232 | 300 页 
countO 函 数 计算 数组 中 的 单元 数目 或 对 象 中 的 属性 个 数 2.10 节 , 实例 125| 163 页 
count0 函 数 取得 字段 数目 8.6 节 ， 实 例 396 | 525 页 
create view 语句 创建 视图 9.2 节 ， 实 例 459 | 604 页 
create db_name 创建 数据 库 函 数 8.2 节 ， 实 例 350 | 473 页 
create procedure 创建 一 个 存储 过 程 9.3 节 ， 实 例 463 | 611 页 
create table 创建 图 书信 息 表 8.3 节 ， 实 例 353 | 477 页 
create trigger 创建 触发 器 9.4 节 ， 实 例 466 | 615 页 
create procedure oracle 中 创建 存储 过 程 12.3 节 , 实例 535| 724 页 
current0 函 数 获取 数组 中 当前 单元 2.10 节 , 实例 136| 171 页 
字母 D 关键 字 索 引 
关键 字 索引 

2.1 节 ， 实 例 035 

2.2 节 ， 实 例 046 

2.4 节 ， 实 例 063 

date0 函 数 获取 系统 的 格林 威 治 时 间 2.8 节 ， 实 例 098 


902 


2.8 节 ， 实 例 106 
2.11 节 , 实例 141 
2.11 节 , 实例 142 
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关 键 字 描 述 索 引 | 页 码 
4.1 节 ， 实 例 224| 288 页 
empty0 函 数 检查 变量 是 否 为 空 4.1 节 ， 实 例 226| 292 页 
4.4 节 ， 实 例 236| 306 页 
encrypt($str) 自 定义 函数 自 定义 加 密 算法 2.2 节 ， 实 例 045| 87 页 
encrypt($stn) 们 自 定义 函数 接收 一 个 参数 ， 执 行 加 密 算法 2.2 节 ， 实 例 052| 94 页 
操作 Access 数据 库 分 页 时 , 检查 当前 记录 集 对 象 所 指 位 置 是 pe 

eof 关键 字 否 为 最 后 一 条 记录 之 后 11.2 节 , 实例 509| 678 页 
13.3 节 , 实例 550| 749 页 
errormsg0) 函 数 返回 最 后 的 状态 或 出 错 信 息 133 节 , 实例 551| 750 页 
escape 变量 用 于 html 转 码 、url 转 码 14.1 节 , 实例 573| 786 页 
11.2 节 , 实例 512| 682 页 

12.1 节 , 实例 S22| 703 页 

12.3 节 , 实例 331| 717 页 

a i 返回 一 个 续 

execute() 函 数 执行 SQL 语句 ， 并 返回 一 个 结果 集 13.1 节 , 实例 538| 732 页 
13.1 节 , 实例 339| 734 页 

13.2 节 ,实例 544| 742 页 

exif read_data0 函 数 从 ;jpeg 或 .tiff 文 件 中 读 取 exif 头 信息 6.1 节 ， 实 例 279| 370 页 
exit 断 开 MySQL 数据 库 连接 8.1 节 ， 实 例 349| 472 页 
wp 将 所 有 的 数据 库 对 象 及 数据 导出 到 文件 中 12.4 节 , 实例 536| 726 页 

inctype= complete file=export.dm 

2.8 节 ， 实 例 087| 131 页 

explode0 函 数 使 用 一 个 字符 串 分 割 另 一 个 字符 串 2.8 节 ， 实 例 090| 133 页 
2.10 节 , 实例 124| 162 页 

explodeslice() 方 法 调用 graph 类 的 方法 对 饼 形 图 进行 分 割 6.3 节 ， 实 例 300| 398 页 
7.3 节 ， 实 例 326| 431 页 

extends 关键 字 类 之 间 继 承 关键 字 78 节 ， 实 例 346| 463 页 
extract0 函 数 从 数组 中 将 变量 导入 到 当前 的 符号 表 14.1 节 , 实例 578| 794 页 

字母 F 关键 字 索 引 
关 键 字 描 述 索 引 | 页 码 

et 4.2 节 ， 实 例 229| 296 页 

felose0 函 数 关闭 一 个 已 经 打开 的 指针 4.4 节 ， 实 例 239| 310 页 
fetehfield0 函 数 和 包含 着 字段 ycolumn number 的 名 称 、 空 间 长 度 等 相 132 节 , 实 例 54| 740 贡 
fetchnextobject0 函 数 返回 当前 指针 所 指向 的 记录 的 对 象形 式 ， 并 且 指 针 自动 下 移 一 行 ”|13.2 节 , 实例 543| 740 页 
fetchrow0 函 数 返回 当前 指针 指向 的 记录 的 数组 13.2 节 , 实例 543| 740 页 
fgets0 函 数 从 文件 指针 中 读 取 一 行 4.4 节 ， 实 例 239| 310 页 
fieldcountO 函 数 返回 结果 集 里 的 字段 数 13.2 节 , 实例 543| 740 页 
a 是 当前 指针 所 指向 的 记录 13.2 节 , 实例 543| 740 页 

fields 关键 字 该 变量 保存 的 是 当前 指针 所 指向 的 记 习 13 2 节 , 实例 549| 748 页 


关键 字 
file0 函 数 


附 ” 录 一 一 字母 索引 


描述 
把 整个 文件 读 入 一 个 数组 中 


索 
4.2 节 ， 


引 
实例 


230 


file_exists() 函 数 


检查 文件 或 目录 是 否 存在 


4.4 节 ， 
4.4 节 ， 
4.4 节 ， 
4.4 节 ， 
4.6 节 ， 


实例 
实例 
实例 
实例 
实例 


233 
234 
235 
237 
253 


file_get_contents() 函 数 


将 整个 文件 读 入 一 个 字符 串 


4.2 节 ， 


实例 
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filectime0 函 数 


取得 文件 的 inode 修改 时 间 


4.4 节 ， 
4.6 节 ， 


实例 
实例 


240 
254 


filemtime 函数 


filemtime 函数 
filesizeO 函 数 


fletypeO 函 数 


final 关键 字 
floor0 函 数 


fopen0 函 数 


for 语句 


返回 文件 最 后 修改 时 间 


获取 文件 修改 时 间 
获取 文件 大 小 


获取 文件 类 型 


被 final 关键 字 修 饰 的 类 不 能 被 继承 
合 去 法 获取 变量 的 整数 值 


打开 文件 或 者 url 


循环 语句 ， 符 合 exprl、 exprl 、exprl 条 件 的 执行 statement 循环 


4.4 节 ， 
4.6 节 ， 
4.4 节 ， 
4.4 节 ， 
4.4 节 ， 
4.6 节 ， 
7.6 节 ， 
15.6 节 ， 
4.4 节 ， 
4.6 节 ， 
2.2 节 ， 
2 和 5 节 ， 
2.5 节 ， 
2.2 节 ， 
22 书 ， 
2.5 节 ， 
2.6 节 ， 
2.6 节 ， 
2.6 节 ， 
2.6 节 ， 
2.6 节 ， 
2.6 节 ， 
2.10 节 ， 
2.11 节 ， 


实例 
实例 
实例 
实例 
实例 
实例 


实例 3 


实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 
实例 


240 
254 
235 
235 
235 
251 


foreach 语句 


遍历 数组 函数 ， 仅 用 于 数组 


2.4 节 ， 
2.8 节 ， 
2.10 节 ， 


实例 
实例 
实例 


format0) 函 数 
fputs0 函 数 
freadO) 函 数 


Access 中 数据 的 格式 输出 
fwrite 别名 
读 取 文 件 〈 可 安全 用 于 二 进 制 文件 ) 


8.7 节 ， 
4.4 节 ， 


4.1 节 ， 


实例 
实例 
实例 
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关 描 述 索 引 | 页 码 
implode 函数 将 数组 合成 字符 串 be 2 
8.7 节 ， 实 例 427| 557 页 
站 关键 字 限定 在 指定 范围 8.7 节 ， 实 例 428| 558 页 
8.7 节 ， 实 例 429| 559 页 
让 关键 字 多 表 之 间 的 嵌 套 查询 可 以 通过 谓词 ip 实现 “|8.7 节 ， 实 例 413| 543 页 
in_array0 函 数 检查 数组 中 是 否 存在 某 个 值 5.2 节 ， 实 例 266| 348 页 
2.3 节 ， 实 例 054| 96 页 
include 语句 包含 PHP 文件 2.4 节 ， 实 例 061| 103 页 
2.9 节 ， 实 例 116| 155 页 
2.3 节 ， 实 例 055| 97 页 
include_once 语句 包含 PHP 文 件 2 5 节 ， 实 例 068| 110 页 
insert into 语句 插入 SQL 语句 Ee 3 人 和 
instanceof 检测 某 实例 是 否 属于 某 一 个 类 的 类 型 7.6 节 ， 实 例 336| 449 页 
interface 关键 字 定义 接口 的 关键 字 7.4 节 ， 实 例 330| 440 页 
intval0 函 数 获取 变量 的 整数 值 2.8 节 ， 实 例 109| 148 页 
is not null 指定 对 空 值 或 非 空 值 的 搜索 8.6 节 ， 实 例 395| 524 页 
is_a0 函 数 指定 的 对 象 是 否 属于 某 类 或 其 子 类 的 对 象 ” |7.6 节 ， 实 例 336| 449 页 
3.1 节 ， 实 例 150| 186 页 
4.1 节 ， 实 例 227| 293 页 
is_dir0 函 数 判断 给 定 文件 名 是 否 是 一 个 目录 4.4 节 ， 实 例 236| 306 页 
4.6 节 ， 实 例 250| 323 页 
4.6 节 ， 实 例 253| 327 页 
is_null0 函 数 检测 变量 是 否 为 空 4.2 节 ， 实 例 229| 296 页 
is_numeric() 函 数 pd 7.1 节 ， 实 例 317| 423 页 
is_readable() 函 数 判断 指定 文件 是 否 可 读 4.4 节 ， 实 例 237| 307 页 
4.1 节 ， 实 例 224| 289 页 
is_uploaded_file0 函 数 判断 指定 的 文件 是 否 是 通过 http post 上 传 ”|4.1 节 ， 实例 225| 291 页 
4.4 节 ， 实 例 244| 316 页 
is_writable(O) 函 数 判断 文件 是 否 可 写 4.4 节 ， 实 例 237| 307 页 
issetO 函 数 检测 变量 是 否 设置 2.2 节 ， 实 例 045| 87 页 
字母 」 关键 字 索 引 
关 描 述 索 引 | 页 码 
jpgraph.php jpgraph 类 库 6.3 节 ， 实 例 289| 328 页 
jpgraph_barphp jpgraph 柱状 图 类 库 6.3 节 ， 实 例 289| 328 页 
jpgraph_linephp jpgraph 折线 图 类 库 6.3 节 ， 实 例 294| 389 页 


附录 一 一 字母 索引 


字母 L 关键 字 索 引 
关 键 字 描 述 索 引 | 页 码 
limit 关键 字 显示 指定 的 ma 条 记录 8.6 节 ， 实 例 388| 516 页 
2.10 节 , 实例 131| 167 页 
一 些 变量 
list0 函 数 把 数组 中 的 值 赋 给 一 些 变量 2 10 节 ,实例 140| 174 页 
literal 标签 将 “{” 与 “}” 之 间 的 内 容 按 普通 的 文本 文件 来 解析 |14.1 节 , 实例 564| 769 页 
ltrim0 函 数 删除 左边 空格 或 特殊 字符 2.8 节 ， 实 例 083| 127 页 
字母 M 关键 字 索 引 
关键 字 描述 索 引 | 页 码 
区 _ 8.6 节 ， 实例 406| 535 页 
max0) 函 数 获取 某 字段 的 最 大 值 8g.6 节 ,实例 407| 537 页 
max execution time0 函 数 PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 秒 4.1 节 , 实例 225| 290 页 
memory_limit0 函 数 PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 分 4.1 节 ， 实 例 225 
标准 化 不 同 数据 库 系统 下 的 数据 类 型 的 表示 法 13.2 节 ,实例 543 
本 二 Pa 2.9 节 , 实例 120| 158 页 
microtime0 函 数 返回 当前 unix 时 间 蕉 和 微 秒 数 2.11 节 , 实 例 148| 182 页 
mid0 函 数 Access 中 获取 某 字 段 中 指定 位 置 的 字符 串 8.7 节 , 实例 433| 564 页 
min0 函 数 获取 某 字段 的 最 小 值 8.6 节 ， 实 例 405| 534 页 
3.1 节 ， 实 例 150| 186 页 
本 4.1 节 ， 实 例 227| 293 页 
mdir0 函 孝 新 建 日 要 4.1 节 , 实例 225| 291 页 
4.4 节 ，, 实例 236| 306 页 
mktime0) 函 数 取得 一 个 日 期 的 unix 时 间 戳 2.11 节 ,实例 
moneyformat0) 方 法 对 货币 金额 进行 格式 化 15.4 节 ,实例 
12.1 节 ,实例 522| 703 页 
move0 函 数 将 adorecordset (结果 集 ) 的 指针 移动 到 指定 位 置 上 和 0 
3.1 节 , 实例 150| 186 页 
move_uploaded file0 函 数 将 上 传 的 文件 移动 到 新 位 置 4.1 节 ， 实 例 224| 228 页 
4.4 节 ， 实 例 236| 306 页 
movefirst0 方 法 将 指针 移动 到 第 一 条 数据 12.1 节 ,实例 522| 703 页 
movelast0 方 法 将 指针 移动 到 最 后 一 条 数据 12.1 节 ,实例 522| 703 页 
movenext0 关 键 字 将 记录 集 对 象 的 指针 向 下 移动 一 条 11.2 节 ,实例 509| 678 页 
mssql_close0 函 数 关闭 数据 库 连 接 的 操作 10.2 节 ,实例 485| 640 页 
a i 8.8 节 , 实例 437| 569 页 
mssql_connect0 函 数 创建 一 个 SQL Server 数据 库 的 连接 10.1 节 , 实 例 471| 623 页 
mssql_data_seek0 〇 函数 行 指针 移动 到 指定 的 行 号 10.2 节 ,实例 474| 628 页 
结果 集中 取得 一 行 加 或 二 
mssql fetch_array0 函 数 aide 人 全 生体 几 8.8 节 ， 实 例 437| 569 页 
mssql fetch assoc0 函 数 从 结果 集中 获取 一 行 作为 关联 数组 10.2 节 ,实例 478| 632 页 
mssql_fetch_field0 函 数 从 结果 集中 获取 列 信息 并 作为 对 象 返回 10.2 节 ,实例 475| 629 页 
Imssql fetch object0 函 数 从 结果 集中 获取 一 行 作为 对 象 10.2 节 ,实例 477| 631 页 


ce ee ee 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


关 键 字 


附录 一 一 字母 索引 


描述 
返回 MySQL 结果 集中 一 个 单元 的 内 容 


索 引 
8.5 节 ， 实 例 368 


页 
492 页 


mysql_result0 函 数 


2.3 节 , 实例 054| 96 页 
2.5 节 , 实例 065| 107 页 
2.5 节 , 实例 069| 113 页 
mysql_select_db0 函 数 选择 MySQL 数据 库 2.5 节 , 实例 066| 108 页 
2.9 节 , 实例 120| 158 页 
2.9 节 , 实例 121| 159 页 
mysqldump -uroot -pl11 db database08> 命令 模式 备份 数据 库 g9 节 , 实例 439| 572 页 
d:\db_database08.txt: 
mysqldump -uroot -proot db_database09 备份 数据 库存 储 过 程 93 节 , 实例 464| 613 页 
> c:/data.sql 
mysqli_closeO 函 数 关闭 连接 9.1 节 ， 实 例 454| 595 页 


Imysqli_connectO 函 数 


9.1 节 ， 实 例 452 


593 页 


mysqli_connect_ermo0 函 数 
li_connect_errorO 函 数 


ID 


9.1 节 ， 实例 452 


593 页 


mysqli_error0 函 数 返回 最 后 一 次 应 用 数据 库 操作 函数 出 错时 的 错误 信息 |9.1 节 , 实例 456| 599 页 
mysqli_fetch_object0 函 数 返回 一 个 由 执行 查询 后 生成 的 表 字 段 组 成 的 对 象 9.1 节 ， 实 例 457| 600 页 


Imysqli_fetch_rowO 函 数 


获得 一 行 结果 数据 


9.1 节 ， 实例 455 


597 页 


9.1 节 ， 实 例 458 

统计 查询 结果 中 的 记录 数 9.1 节 ， 实 例 458 

li_real_connect0 函 数 建立 与 MySQL 数据 库 服务 器 的 连接 9.1 节 ， 实例 456 
mysql-uname-tpassword 命令 连接 MySQL 服务 器 指令 8.1 节 ， 实例 348| 471 页 

字母 N 关键 字 索 引 
关 键 字 描 述 索 引 | 页 码 

net start mysql0 命 令 启动 MySQL 服务 器 命令 8.1 节 ， 实例 347| 470 页 
net stop mysql0 命 令 | 关闭 MySQL 服务 器 命令 8.1 节 ， 实例 349| 472 页 
new 关键 字 用 于 实例 化 对 象 7.1 节 ， 实 例 314| 419 页 
not between...and... 查询 所 有 不 在 该 范围 内 的 记录 8.6 节 ， 实 例 395| 524 页 
not in 指定 表达 式 的 搜索 8.6 节 ， 实 例 395| 524 页 
not 关键 字 如 果 原 来 表达 式 或 参数 的 值 为 逻辑 真 ， 则 取 非 运算 后 8.6 节 ,实例 383| 511 页 


的 结果 为 逻辑 假 


notin 关键 字 限定 不 在 指定 范围 8.7 节 ， 实 例 427| 557 页 
null 预定 义 常 量 一 个 null 值 2.1 节 ， 实 例 036| 79 页 
number format 函数 金额 的 格式 化 输出 2.8 节 ， 实 例 097| 139 页 
字母 O 关键 字 索 引 
关 键 字 描 述 索 引 | 页 码 
oci_bind_by_name0 函 数 绑 定 一 个 PHP 变量 到 一 个 Oracle 位 置 标识 符 12.2 节 ,实例 523| 704 页 
oci_close0 函 数 关闭 数据 库 12.2 节 ,实例 523| 705 页 
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pconnect0 函 数 


附 ” 录 一 一 字母 索引 


描述 


持久 化 连接 


索 


121 节 ， 
13.1 节 ， 
132 节 ; 


引 
实例 521 
实例 538 
实例 544| 


页 码 
701 页 
732 页 
742 页 


php_os 预定 义 常量 


内 建 常量 ， 执 行 PHP 解析 器 的 操作 系统 名 称 ， 如 Windows 


2.1 节 。 


实例 036 


79 页 


php_version 预定 义 常量 


内 建 常 量 ，PHP 程序 的 版 本 ， 如 3.0.8_dev 


2.1 节 ; 


实例 036| 


79 页 


pow0 函 数 


计算 某 个 数 的 n 次 方 罕 


VA 


实例 322 


429 页 


preg_match0 函 数 


preg_replace0 函 数 


进行 正则 表达 式 匹配 


执行 正则 表达 式 的 搜索 和 替换 


print_r0 函 数 


private 关键 字 
protected 关键 字 


public 关键 字 


打印 关于 变量 的 易于 理解 的 信息 


表示 该 类 只 能 在 类 体内 被 调用 


表示 该 方法 可 以 在 类 中 或 该 类 的 子 类 中 被 调用 


表示 该 成 员 可 以 在 任何 范围 被 调用 ,包括 类 体内 部 、 该 类 的 子 类 和 类 


实例 的 对 象 


7 
2S 节 ， 
29 节 。 
2.9 节 ， 
2.9 节 ， 
2.9 节 ， 
27 节 : 
2.9 节 ， 
2.8 节 ， 


2.10 节 ， 
2.10 节 ， 
2.10 节 ， 
,实例 132 
,实例 138 
,实例 139 


2.10 节 


2.10 节 
2.10 节 


2.10 节 


7.1 节 ， 
7.2 节 ， 


7.1 节 ， 


实例 082 
实例 110 
实例 116 
实例 117 
实例 122 
实例 123 
实例 081 
实例 121 
实例 087 
实例 124 
实例 126 
实例 127 


例 140 
314 
344 
实例 314 
实例 325 


实例 314 


126 页 
149 页 
155 页 
156 页 
160 页 
161 页 
125 页 
160 页 
131 页 
162 页 
164 页 
164 页 
168 页 
172 页 
173 页 
174 页 
418 页 
459 页 
418 页 
433 页 


419 页 


pwdcompare0 函 数 SQL Server 数据 加 密 效 验 10.4 节 ,实例 502| 667 页 
pwdencrypt0 函 数 SQL Server 数据 加 密 10.4 节 ,实例 502| 667 页 


query 


MySQL 中 要 执行 的 查询 语句 


9.1 节 ， 
9.1 节 ， 


实例 451 
实例 453 


591 页 
594 页 


quotemeta0 函 数 


关键 字 


特殊 字符 的 原样 输出 
字母 R 关键 字 索 引 
描 述 


2.8 节 ， 


索 


实例 103 


引 


143 页 


页 码 


TandO 函 数 


产生 一 个 随机 整数 


2.5 节 ， 
2.6 节 ， 
2.6 节 ， 


实例 072 
实例 074| 
实例 075 


2.10 节 ,实例 132 


116 页 
118 页 
119 页 
168 页 


readdir0 函 数 


从 目录 句柄 中 读 取 条 目 


4.6 节 ， 
4.6 节 ， 
4.6 节 ， 


实例 250 
实例 252 
实例 253 


323 页 
326 页 
327 页 
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续 表 
关 键 字 描 述 索 引 | 页 码 
readfile0 函 数 输出 一 个 文件 4.2 节 , 实例 230| 297 页 
readystate 属性 请 求 的 状态 14.1 节 ,实例 567| 775 页 
TecordcountO 函 数 返回 结果 集 里 的 记录 数 13.2 节 ,实例 543| 740 页 
regex_ replace 变量 Smarty 模板 中 的 正则 表达 式 14.1 节 ,实例 574| 787 页 
register function0 方 法 “| 动态 注册 模板 函数 插件 14.1 节 ,实例 578| 794 页 
register_object0 方 法 注册 一 个 在 模板 中 使 用 的 对 象 14.1 节 ,实例 577| 791 页 
rename table 重 命名 数据 表 8.3 节 , 实例 356| 479 页 
4.4 节 , 实例 232| 300 页 
rename() 函 数 重 命名 一 个 文件 或 目录 4.4 节 , 实例 234| 303 页 
4.6 节 ， 实例 251| 324 页 
2.3 节 , 实例 053| 95 页 
require 语句 包含 PHP 文 件 2.3 节 , 实例 056| 98 页 
2.5 节 , 实例 068| 110 页 
2.3 节 , 实例 057| 99 页 
Tequire_once 语句 包含 PHP 文件 2.9 节 , 实例 117| 156 页 
2.9 节 , 实例 123| 161 页 
responsetext 属性 服务 器 的 响应 ， 表 示 为 字符 串 14.1 节 ,实例 567| 775 页 
responsexml 属性 服务 器 的 响应 ， 表 示 为 xml 14.1 节 567| 775 页 
revoke create 取消 存储 过 程 权限 12.3 535| 724 页 
王 4.6 区 ,实例 250| 322 页 
a 删除 旧 条 4.6 节 , 实例 254| 328 页 
i i 9.4 节 , 实例 468| 617 页 
Iollback0 方 法 利用 mysqli 类 中 的 该 方法 可 以 实现 事务 的 回 深 95 节 ,实例 469| 619 页 
rollbacktransO 函 数 结束 一 次 操作 ， 恢 复 操作 前 的 所 有 改变 13.2 节 ,实例 549| 748 页 
round0 函 数 将 数字 小 数位 进行 四 舍 五 入 操作 6.4 节 , 实例 311| 411 页 
13.2 节 ,实例 541| 738 页 
Wy 4 结 
Is2html0 函 数 返回 一 个 html 表格 格式 的 结果 集 132 节 ,实例 547| 746 页 
rtrim0 函 数 删除 右边 空格 或 特殊 字符 2.8 节 , 实例 083| 127 页 
字母 S 关键 字 索 引 
关键 字 描 述 索 引 页 码 
14.1 节 ,实例 569| 779 页 
Re en 
section 语句 用 于 比较 复杂 的 数组 15.4 节 ,实例 599| 834 页 
nt | 87 节 , 实例 410| 540 页 
where 条 件 … 
select 字段 名 from 表 1. 表 2… where 表 1. Es i 
字段 - 表 2 字段 and 其 他 查询 条 件 多 表 查 询 8.7 节 , 实例 409| 539 页 
select fieldlist from tablel [inner] join table2 内 连接 查询 g7 节 , 实例 421| 551 页 


ontablel.column1l=table2.columnl 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


附录 一 一 字母 索引 


索 引 


续 表 
页 码 


switch 语句 


关 键 


template dir 


要 


time0 函 数 


transform 关键 字 
trim0 函 数 

true 预定 义 常量 
truncate tb_name: 


truncate0 方 法 


try/catch 语句 


关键 字 


指定 的 代码 


字母 关键 字 索 引 
描述 
模板 目录 存储 位 置 


返回 当前 的 unix 时 间 稚 


创建 交叉 表 查 询 

删除 字符 串 两 边 的 空格 或 特殊 字符 
该 常量 是 一 个 真 值 (tme) 

清空 数据 表 信息 


从 字符 串 开始 处 截取 指定 长 度 的 字符 ， 默 认 是 80 个 字符 


选择 语句 ， 当 符合 条 件 时 ,根据 传 入 的 参数 ,执行 


异常 捕获 
字母 U 关键 字 索 引 
描 述 


2.3 节 , 实例 053 
2.3 节 , 实例 057 
2.4 节 , 实例 061 
2.4 节 , 实例 062 
2.4 节 ,， 实例 063 
2.5 节 ， 实例 068 
2.6 节 ,实例 073 
2.11 节 ,实例 141 


索 引 
14.1 节 ,实例 558 
2.8 节 ， 实例 106| 
2.11 节 ,实例 142 
2.11 节 ,实例 144 


15.4 节 ,实例 603 
15.4 节 ,实例 604 
7.6 节 ， 实例 334 


95 页 
99 页 
103 页 
104 页 
105 页 
110 页 
117 页 
176 页 


页 码 
760 页 
146 页 
176 页 
178 页 
179 页 
179 页 
181 页 
560 页 
561 页 
138 页 
79 页 
483 页 
796 页 
842 页 
844 页 
446 页 


页 码 


ucfirstO 函 数 


定义 首 字母 大 写 


148 页 


union 关键 字 


利用 该 关键 字 可 以 将 多 个 select 语句 的 查询 结果 合 
重复 行 


fF 输出， 


删除 


541 页 
548 页 


unlinkO 函 数 


用 于 删除 文件 


300 页 


update table_name 


执行 修改 操作 


482 页 
497 页 
499 页 


Upload _ max _filesize0 函 数 


服务 器 允许 上 传 文件 的 最 大 值 ， 以 M 为 单位 


290 页 


urldecode0 函 数 


urlencode0 函 数 


实现 对 ul 解码 
实现 对 rl 编码 


143 页 
142 页 
143 页 


use 语句 


指定 默认 数据 库 


474 页 


917 


PHP 开发 实战 1200 例 (第 I 卷 ) 


字母 W 关键 字 索 引 
关 键 字 描 ” 述 索 引 页 码 
a s 2.5 节 , 实例 064| 107 页 
while (expr) {statement} 循环 语句 ， 当 符合 条 件 expr 时 执行 statement 语句 部 分 2.5 节 , 实例 066| 108 页 
wordwrap0 函 数 指定 段落 的 宽度 14.1 节 ,实例 576| 790 页 
字母 X 关键 字 索 引 

关 键 字 描述 索 引 

xp_cmdshellfcommand_string) | 以 操作 系统 命令 行 解释 器 的 方式 执行 给 定 的 命令 字符 让 ele i Ce 
其 他 关键 字 索 引 

关 键 字 描 述 索 引 页 码 
S$_env 预定 义 变量 tn 操作 系统 的 环境 和 本 地 操作 系 | 1 节 ， 实 例 041| 84 责 
(expr) ? {statementl;} : {statement2:} 机 条 作为 光 时 :执行 Ranctl 尘 出 2.2 节 ， 实 例 047| 90 页 
__autoload() 方 法 自动 加 载 文件 7.7 节 ， 实 例 343| 458 页 
__call(0 方 法 调用 类 中 一 个 不 存在 或 不 可 见 的 方法 时 ， 将 执行 该 方法 |7.7 节 ， 实 例 339| 453 页 
__Construct0 函 数 构造 方式 实现 类 的 初始 化 7.1 节 , 实例 314| 419 页 
_file _ 预 定义 常量 文件 的 完整 路 径 和 文件 名 2.1 节 , 实例 036| 79 页 
get0 方 法 获得 类 中 未 定义 属性 的 值 7.7 节 , 实例 338| 452 页 
_isset() 方 法 判断 类 中 未 定义 的 属性 是 否 被 设置 时 所 调用 7.7 节 , 实例 341| 455 页 
_line _ 预 定义 常量 PHP 程序 行 数 2.1 节 , 实例 036| 79 页 
__set0 方 法 存 取 类 中 未 声明 的 属性 7.7 节 , 实例 337| 450 页 
_tostring0 方 法 类 实例 的 对 象 转换 为 字符 串 7.7 节 ， 实 例 340| 454 页 
_unset0 方 法 撤销 类 中 未 定义 的 属性 时 调用 7.7 节 , 实例 342| 457 页 
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